اللهم صلى وسلم على سيدنا محمد و على آله وصحبه أجمعين 
a‏ | دالج دا السورية 
لجمهورية العربية السوري 


" أقرا باسم ربك الذي خلق » خلق اللإنسان من علق » 


أقرا وربك الأكرم الذي علم بالقلم علم الإكيان مالم يعلم " 


برامج بلغة سي بلس بلس 


C++ 


Engineer: Khaled yassin alsheikh 
إعداد المهندس خالد ياسين الشيخ‎ 


khaledyassinkh @ 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك بالميي اشح khaledyassinkh @gmail.com‏ 


برامج بلغة ++ (الجزء الثاني) 
جميع sاںماںہ‏ من الیسار لليمين programs in c++‏ 
الخرج: في حال أدخلنا 355م هو: #include<iostream.h>‏ 
#include<conio.h>‏ 
void p(char * a){ a. password correct‏ 
int i=0; pass‏ 
while(i<4)‏ 
cout<<a[i++]; Kokko‏ 


cout<<endl; password correct 


pass 


main(){ oR Rk Fk 


int s=0; error please enter new password 
char x[]="pass" , pass[4]; 

for(i e 
for(int i=0;i<4;i++){ password correct 
pass[i]=getch(); 
الجواب الصحيح يختلف عما سبق .ع انوع‎ 

1 

for(i=0;i<4;i++){ 
if (pass([i]==X([i]) s++; ملاحظة: التابع ععع تقوم بقراءة المحرف دون إظهار المحرف المدخل‎ 
else على الشاشة و التابع موجود في المكتبة .هأمهء ولذلك يجب تضمين هذه‎ 
المكتبة قبل استخدام هذا التابع‎ 
و في حال أردت إظهار المحرف المدخل على الشاشة استخدم التابع‎ 
getche() 


break; 


cout<<"\npassword 
correct"<<endl; 
break; 
1 
cout<<endl; 
cout<<"error please enter new 
password"<<endl; 
s=0; 
} 
p(pass); 
getch(); 
return O; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


الخرج: 
يتم طباعة 31/3116 613/ا5 بشكل لا نهائي لأن البرنامج يدخل في حلقة 
لا نهائية. لأن حلقة ۲ه لا نهائية. 


بلغ عدد سكان الجمهوية العربية السورية عام 1980 حوالي 12 مليون نسمة 
و إذا علمت أن معدل تزايد السكان السنوي يبلغ حوالي 2.396 تقريبا و 
المطلوب كتابة برنامج بلغة ++ يقوم بمايلي: 

© 

لكي يتضاعف عدد السكان حيث يتم طباعة 

السنة ,علا التي يتضاعف فيها عدد السكان. 
عدد السنوات. 
عدد السكان حينها. 


الخرج: 


year =2011 
number of years =31 
number of population =24284316.874 


اكتب إجرائية ع3 بلغة ++ يمرر إليها عدد حقيقي بفاصلة و تقوم 


ويراد الحل بدون استخدام أي تابع جاهز. 


مثال: 

تم تمرير العدد 33.3 يتم طباعة 333/10 
تم تمرير العدد 22.4 يتم طباعة 112/5 
تم تمرير العدد 0.5 يتم طباعة 1/2 

تم تمرير العدد 0.25 يتم طباعة 1/4 

تم تمرير 4.125 يتم طباعة 33/8 

تم تمرير 50.2 يتم طباعة 251/5 


۾ خالك الائ 


إجراء 36100انام0م يقوم بحساب و طباعة عدد سنوات اللازمة 


khaledyassinkh @gmail.com 
#include<iostream.h> 
#include<ctype.h> 
void main(){ 
while (true){ 
for(;;) 
cout<<"syria arabic"<<endl; 
I(1) 
break; 


} 


#include<iostream.h> 


#include <iomanip.h> 
void population(double n){ 
double temp=n; 
long year=1980, i=0; 
while(n<2*temp){ 
A=R*1.023; 
year++; 
i++; 


} 
cout<<"year ="<<year<<endl; 
cout<<"number of years 
="<<i<<endl; 
cout<<"number of population 
="<<setprecision(11)<<n<<endl; 
/ 
void main(){ 
double n=12000000; 
population(n); 


#include<iostream.h> 
#include<stdio.h> 
void f(double & n){ 
MERZ: 
} 
void frac(double n1){ 
double n2,n3,m; 
1ن‎ 
int t=n1; 
n2=n1-t;jint i=1; 
while(n2!=0){ 
i++; 
RIZA 
RL; 
n2=n1-t; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 
if(n2!=0)‏ 
n1=m;‏ 

} 

cout<<n1<<"/"<<i<<endl;; 
} 
void main(){ 

double n1; 

cin>>n1; 

frac(n1); 


#include<iostream.h> 
#include<conio.h> 
int countcall(void){ 
static int count=O0; 
count++; 
return (count); 
} 
main(){ 
cout<<countcall()<<","; 
cout<<countcall()<<","; 
cout<<countcall()<<endl; 


#include<iostream.h> 
int main(){ . syria 
كعم‎ . welcome to syria 
if(x>5) „. syriawelcome to syria 
if(x%2==1) . لا يتم طباعة أي شىء‎ 
cout<<"syria"; . الجواب الصحيح يختلف عما سبق‎ 
else 
cout<<"welcome to syria"; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي اشح‎ 
#include<iostream.h> الخرج:‎ 
#include<conio.h> 
char *f1(int); 
char *f2(int); 
char *f1(int generations){ 
if(generations==0) لاخظ عملة الاستتعغاعات؟‎ 
return ("f1"); ی‎ 
else 
return(f2(generations-1)); 
} 
char *f2(int generations){ 
if(generations==0) 
return ("f2"); 
else 
return (f1(generations-1)); 
/ 
void main(){ 
cout<<f1(5)<<endl; 
cout<<f1(5+5)<<endl; 
cout<<f2(10)<<endl; 
cout<<f1(6)<<endl; 


#include<iostream.h> 


#define sqr(n) n*n a. 19.36.81‏ 
main(){ b. 16.36,81‏ 
NOREEN, ¢. 16.116,16‏ 
MEE; d. 18.32/41‏ 
الجرأب الضصحيخ يختلف: عما سيق: م cout<<sqr(m)<<endl;‏ 
ملاحظة: الماكرو يشبه التابع مع بعض الاختلافات ويمتاز الماكرو عن التابع 
بالسرعة و سهولة في كتابته و استخدامه أنواع مختلفة من المعطيات دون 
تحديد المعطيات في ترويسته. 


#include<iostream.h> 

#include<math.h> 

main(){ 
int a=100,b(2),c=20,d=30,e=1,f=128; 
c=sqrt(int(a/b)*3); 
d=fmod(a/pow(b,2),4); 
e=ceil(c/b*0.2); 
f=floor(((a+tb+c+d)*2)/2); 
coté" اممةعع»ه" بواج‎ 
"مهنو‎ is; "<<d<<endl; 
cout<<"e is: "<<e<<endl; 
cout<<"f is: "<<f<<endl; 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


الخرج: 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


syria 

welcome to syria 
welcome to syria 
good luck 

I'm From syria 
syria- damascus 
information 

I'm From syria 
syria- damascus 
information 
syria- damascus 
information 
information 


Ox00428D50 
Ox00428D50 


۾ خالك الاثي 


khaledyassinkh @gmail.com 


#include<iostream.h> 
main(void){ 

int s=1; 

001 

5(1)اء]أللاك 

case 1:cout<<"syria"<<endl; 
case 2: cout<<"welcome to 
syria"<<endl;break; 
case 3:cout<<"good luck"<<endl; 
case 4:cout<<"I'm From syria"<<endl; 
case 5:cout<<"syria- damascus "<<endl; 
default:cout<<"information"<<endl; 

/ 

S++; 
] 
while(s<7); 
#include<iostream.h> 
#include<conio.h> 
int x=100; 
int & f1(){ 

return X; 
} 


void main(){ 


f1()=x; 
f1()-=10; 
XH+; 
cout<<x<<endl; 
cout<<f1(); 
getch(); 
} 
#include<iostream.h> 
#include<conio.h> 
int x=100; 
int & f1(){ 
return X; 
} 


void main(){ 


f1()=x; 
f1()-=10; 
XH+; 
cout<<&x<<endl; 
cout<<&f1()<<endl; 


getch(); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي اشح‎ 
#include<iostream.h> الخرج:‎ 
#include<conio.h> 
int x=100; 
int *p=&x; 
int * 101 

return زم‎ 


} 


void main(){ 
10-2; 


لمجي 
*p+=1;‏ 
cout<<x<<endl;‏ 
cout<<*f1()<<endl;‏ 
cout<<*p<<endl;‏ 
getch();‏ 

/ 

#include<iostream.h> 

#include<conio.h> 

int x=100; Ox00428D50 

int *p=&x; Ox00428D50 

int * f1(){ Ox00428D50 
return زم‎ 

} 

void main(){ 
IS2: 
XH+; 
*p+=1; 
cout<<&x<<endl; 
cout<<f1()<<endl; 
cout<<p<<endl; 
getch(); 

] 

#include<iostream.h> 

#include<conio.h> Ox00428D50 

int x=100; Ox00428D50 

int *p=&x; 4 

int * f1(){ 4 

return زم‎ 

} 

void main(){ 
10)52; 
XH+; 

pJ) 

cout<<&x<<endl; 

cout<<f1()<<endl; 

cout<<*p<<endl; 


cout<<*p<<endl; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


getch(); 


#include <iostream.h> 
template< class T > Array a contains: 
void printArray( const T *array, const int 12345 
count ) Array b contains: 
1 1.1 2.2 3.3 4.4 5.5 6.6 7 
for (inti = 0: i < count; i++ ( Array c contains: 
cout >> array[ i ] << " "; HELLO To SYRIA 


cout << endl; 


int main() 
{ 

const int aCount = 5, bCount = 7, cCount = 
15; 


int al aCouRÊ |= {L234 

double b[ bCount ] = {1.1, 2.2, 3.3, 4.4, 5.5, 
6677 

chaf él أتروقعة‎ [ = "HELLO 5“ 

cout << "Array a contains:" << endl; 


printArray( a, aCount ); 

cout << "Array b contains:" << endl; 
printArray( رط‎ bCount ); 

cout << "Array c contains:" << endl; 
printArray( c, cCount ); 

return O; 


#include<iostream.h> 
int main(void){ the address of a 80127 
int a; 
int *p; the contents stored in م‎ 0127 
a57; 
p=&a; the stored in a is7 


cout<<"the address of a is"<<&a<<"\n\nthe the value to which p pointer is7 

contents stored in p is"<<p; و يمكن تمتيل ذلك بالذاكرة الرئيسية كما يلي:‎ 
cout<<"\n\nthe stored in a is"<<a<<"\n\nthe 
value to which p pointer is"<<*p<<endl; 


۾. خلك اللشيدج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


Memory address Variable a(7)-integer is 4 bytes 


OxOO012FF7C 00000000 00000000 00000000 00000111 


الخرج: 


Assalamu Alaikum 


فائدة(التوابع السطرية) ٥۸‏ ااءہں؟ ٥ہ‏ اہ و الفرق يبينها وبين 6100ل 
التوابع العادية 


لدينا التابع التالي: 
int sqr(int (1‏ 
return (x*x);‏ 
} 


حيث عمل هذا التابع هو أنه يعطينا مربع عدد مدخل و في التابع الرئيسي 
نستطيع أن نكتب هذا الاستدعاء وفي كل مرة يتم التعريف التابع على أنه 
مامأ يقوم المترجم باستبدال التابع بالتابع نفسه. 

int x=sqr(10); 


قيمة × هي ٠١١-1١*٠١‏ لنتخيل أننا استخدمنا التابع السابق لتربيع ٠٠١‏ 
رقم في حلفة +0 مثلا و في كل مرة يصل المترجم إلى تنفيذ التابع يتم 
استدعاء التابع و تنفيذ ما بداخله ثم إرجاع القيمة إلى المتحول × 


و لكن في هذه الحالة نذهب ثم نعود للتابع الرئيسي 200 مثلا وهذا يأخذ 
الوقت 


inline int sqr(int x){ 
return (x*x); 


} 


يمكنك استدعاء التابع تماما كما فعلنا في المرة السابقة» و لكن هذه المرة عند 


۾ خالك الائ 


khaledyassinkh @gmail.com 
return O; 


} 


#include<iostream.h> 
void main(){ 
int =2, X55, * لاه دم‎ 
*p=3; 
1ك[‎ 
while(i!=0){ 
İf(i %2==0) 
cout<<"Assalamu 
Alaikum"<<endl; 
| 
} 
#include<iostream.h> 
inline Double(int); 
void main(){ 
int target=6; 
target=Double(target); 
cout<<"Target="<<target<<endl; 
target=Double(target); 
cout<<"Target="<<target<<endl; 
target=Double(target); 
cout<<"Target="<<target<<endl; 


inline Double(int target){ 
int result; 
result=2*target; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك يالميي اشح khaledyassinkh @gmail.com‏ 
استدعاء التابع سيقوم المترجم خلال عملية الترجمة بالتالي: 


int=x*x; 


سيتم استبدال التابع ووضع »×*× مباشرة و بالتالي لم يعد هناك ذهاب و عودة 
إلى التابع 


الخرج: 


Target=12 
Target=24 
Target=48 
ملاحظة هامة:‎ 


ينصح استخدام التوابع السطرية فقط مع التوابع الصغيرة . 


التوابع السطرية تزيد من سرعة التنفيذ في حال التوابع الصغيرة. 


#include<iostream.h> الخرج:‎ 
#include<iomanip.h> 
inline int sqr(int n){ 
return n*n; 
} 
void main(){ 
for(int i=1;i<=10;i++) 
cout<<i<<setw(4)<<sqr(i)<<endl; 


1 
2 
3 
4 
5 
6 
7 
8 
9 


سلسلة فيبوناشي #include<iostream.h> :(Fibonacci series)‏ 
هي سلسلة من الأرقام حيث أنه أي رقم في هذه السلسلة يساوي مجموع void Fibonacci(int n){‏ 
الرقمين السابقين له و يكون الرقم الأول من السلسلة و الثاني منها يساوي int a=1,b=a;‏ 
الواحد ;" cout<<a<<" "<<b<<"‏ 
مثال: for(int i=3;i<=n;ji++){‏ 
int s=a+b; 1123 5 813 21 4‏ 
و المطلوب كتابة برنامج بشكل تكراري يقوم بإيجاد عناصر سلسلة فيبوناشي ;" cout<<s<<"‏ 
من أجل 6 عنصر . a=b;‏ 
b=s;‏ 
} 
cout<<endl;‏ 
} 
void main(){‏ 
int n=9;‏ 
Fibonacci(n);‏ 


۾. خلك للج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي اشح‎ 
#include<iostream.h> اكتب بلغة ++ برنامج يقوم بفرز نسق وطباعته.‎ 
sort(int v[],int n){ 
int i,j; تت‎ 
for(i=0;i<n;i=i+1) 
for(j=i-1;j>=0&&v[j]>v[j+1];j=j-1) 
{ 
int t=v[j]; 
vljl=v[j+1]; 
vlj+1]=t; 
1 
} 
print(int a[],int n){ 
Int =0; 
while(i<n) 
cout<<a[i++]; 
cout<<endl; 


} 


void main(){ 
int a[5]={5,4,3,2,1}; 
print(a,5); 
sort(a,5); 
print(a,5); 


1 
#include<iostream.h> اكتب برنامج يعمل على قراءة م قيمة صحيحة ثم يحسب الوسط الحسابي و‎ 
#include<math.h> الانحراف المعياري لهذه القيم باستخدام الأنساق.‎ 
int sqr(int n){ 
return n*n;} 
void main(){ 
66055 51 HES; 
int *mat=new int[n]; 
int i,sum=0; 
double val=0,avr,s; 
for(i=0;i<n;i++){ 
cout<<"enter the value "<<i+1<<endl; 
cin>>mat[i]; 
sum+=mat[i]; 
1 
avr=(float)sum/n; 
for(i=0;i<n;i++) 
val+=sqr(mat([i]-avr); 
s=sqrt(val/n); 
cout<<"average="<<avr<<endl; 
cout<<"S="<<s<<endl; 
delete[]mat; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


ل لإمجحددي. خا لدي لايح 
-١‏ اكتب بلغة ++ تابع 011110117 يعيد أصغر عنصر في المصفوفة(نسق). 
؟- اكتب بلغة ++ تابع صuص1×هم‏ يعيد أكبر عنصر في المصفوفة(نسق). 
الخرج: 
8.2 
1.5 


khaledyassinkh @gmail.com 


#include<iostream.h> 
#include<conio.h> 


double min(double *mat,int n) 
١ 
int i=0; 
double s=*(mat+i); 
for( i=1;ji<n;ji++) 
if(mat[i]<s) 
s=mat[i]; 
return s; 
return -1; 


1 


double max(double *mat,int n) 
{ 
int i=0; 
double s=*(mat+i); 
for( i=1;ji<n;ji++) 
if(mat[i]>s) 
s=mat[i]; 
FEU S, 
return -1; 
! 
#define n 0 
int main(void){ 
double 
mat[n]={5,8,6,2,2.5,1.5,7,7.9,8.2,1.9}; 
cout<<max(mat,n)<<endl; 
cout<<min(mat,n)<<endl; 
return 0 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي للح khaledyassinkh @gmail.com‏ 
المطلوب:برنامج يقوم بضرب مصفوفتين حيث : #include<iostream.h>‏ 
لدينا مصفوفتين ثنائية البعد المصفوفة ۸ تحوي م سطر و مم عمود و #include<iomanip.h>‏ 
المصفوفة 8 تحوي )| عامود و م سطر لأن شرط الضرب يجب أن يكون const int n=10;‏ 

محققاً و بالتالي فإن عدد أعمدة المصفوفة ۸ و أسطر المصفوفة 8 متساوي. const int m=8;‏ 

اكتب إجرائية اام تقوم بعملية الضرب ووضع الناتج في مصفوفة ثالثة ©. const int k=12;‏ 

void mult(int A[][m],int B[][k],int 
61111 


for(int i=0;i<n;ji++) 
for(int j=0;j<k;j++){ 
6101-0 
for(int 
1=0;jl<m;l++) 


نا [ا]8* إن إناكك؟ [ز][أ]ء 
} 
} 
void read1(int a[][m]){‏ 
for(int i=0;i<n;i++)‏ 
for(int j=0;j<m;j++){‏ 


couts<"A[("<<i<<"]"<<" ["<<j<<"]"; 
cin>>a[i]]; 
/ 
/ 
void read2(int b[][k]){ 
for(int i=0;i<n;ji++) 
for(int j=0;j<k;j++){ 


cot" BSS TEST: 
cin>>b[i][j];} 
} 
void print(int C[][k]){ 
for(int i=0;i<n;i++){ 
for(int j=0;j<k;j++) 


cout<<setw(4)<<C[i][j]<<setw(4); 
cout<<endl; 


} 


void main(){ 
int A[n][m]; 
int B[m][k]; 
int C[n][k]; 
read1(A); 
read2(B); 
mult(A,B,C); 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 
print(C);‏ 


اكتب برنامج يعمل من خلال سجل على إدخال بيانات تتعلق ب 6 شخص و #include<iostream.h>‏ 
يحوي السجل الاسم الأول 0306 و الاسم الأخير ©03006/ و العمر ©38 . struct pers{‏ 
و تخزين هذه البيانات في مصفوفة غ703 ثم يرتب هذه البيانات ترتيبا char fname[20];‏ 
تصاعديا و في حال تساوي الاسم الأول يفحص الكنية. ثم يقوم البرنامج char Iname[20];‏ 
بطباعة البيانات قبل وبعد الفرز. int age;‏ 
j‏ 
void insertdata(pers mat[],int n){‏ 
for(int i=0;i<n;ji++){‏ 
cin>>mat[i].fname;‏ 
cin>>mat[i].lIname;‏ 
cin>>mat[i].age;‏ 


] 
] 


void swap(pers mat[],int i,int j){ 
pers t=mat[i]; 
mat[i]=mat[j]; 
matlj]=t; 

] 

void sortdata(pers mat[],int n){ 
for(int i=0;i<n-1;ji++) 

for(int j=0;j<n-1;j++) 


if(mat[j].fname>mat[j+1].fname) 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي للح khaledyassinkh @gmail.com‏ 
swap(mat,j,j+1);‏ 
else‏ 


if(mat[j].fname==mat([j+1].fname){ 
if(mat[j].lIname>mat[j+1].lIname) 


swap(mat,j,j+1);} 
} 
void print(pers mat[],int n){ 
for(int i=0;i<n;ji++) 
cout<<mat[i].fname<<" 
"<<mat[i].lIname<<" "<<mat[i].age<<endl; 


} 


void main(){ 
It f; 
cout<<"enter size array "; 
cin>>n; 
pers * mat=new pers[n]; 
insertdata(mat,n); 
cout<<" "<<endl; 
print(mat,n); 
cout<<" "<<endl; 
sortdata(mat,n); 
print(mat,n); 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك لابجتددب. خلك بسي اشح khaledyassinkh @gmail.com‏ 
المطلوب كتابة بلغة C++‏ برنامج يقوم بتعريف مصفوفة من الأعداد #include<iostream.h>‏ 
الصحيحة تحوي + سطر و ع عمود . #include<iomanip.h>‏ 
كتابة إجرائية "٣م‏ لطباعة المصفوفة بطريقة مرتبة (صفوف const int r=3,c=4;‏ 
و أعمدة) void print(int a[][c]){‏ 
كتابة W‏ ٠۲٥ء٣٠۷٠‏ لطباعة بترتيب عكسي للصفوف for(int i=0;ji<r;i++){‏ 
كتابة ٣نامع‏ لطباعة كل عمود بسطر. for(int j=0;j<c;j++)‏ 
كتابة إجرائية Wه‏ ٣ء‏ لطباعة مجموع كل صف. cout<<a[i][j]<<setw(4);‏ 
كتابة إجرائية مامط]باامءممنو لطباعة مجموع كل عمود. cout<<endl;‏ 
كتابة إجرائية "ںام ×ه م لطباعة العنصر الأكبر من كل } 
عمود 
كتابة إجرائية ٣٥W‏ ×ه مم لطباعة العنصر الأكبر من كل صف void reverserow(int a[][c]){‏ 
تابع "ناء يعيد مجموع عناصر المصفوفة ككل. for(int i=0;i<r;i++){‏ 
for(int j=c-1;j>=0;j--)‏ 


cout<<a[i][j]<s<setw(4); 
cout<<endl; 
/ 
} 
void columnl(int a[][c]){ 
for(int j=0;j<c;j++){ 
for(int i=0;i<r;ji++) 


cout<<a[i][j]<s<setw(4); 
cout<<endl; 
/ 
} 
void sumrow(int a[][c]){ 
int sum; 
for(int i=0;i<r;ji++){ 
sum=0; 
for(int j=0;j<c;j++) 
sum+-=a[i][j]l; 


cout<<"row"<<i+1<<"="<<sUum; 


cout<<endl; 


} 
void sumcolumnl(int a[][c]){ 
int sum; 
for(int j=0;j<c;j++){ 
sum=0; 
for(int i=0;i<r;ji++) 
sum+=a[i][j]; 
cout<<"column"<<j+1<<"="<<sum; 
cout<<endl; 


} 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


۾ خالك اللشيدت 


khaledyassinkh @gmail.com 
void maxcolumnl(int a[][c]){ 
int max; 
for(int j=0;j<c;j++){ 
max=a[0][i]; 
for(int i=1;i<rji++) 
if (a[i][j]>max) 
max=a[i][j]; 


cout<<"maxcolumn"<<j+1<<"="<<max 


cout<<endl; 


} 
} 
void maxrow(int a[] [c]){ 
int max; 
for(int i=0;i<r;ji++){ 
max=a[i][0]; 
for(int j=1;j<c;j++) 
if(a[i][j]>max) 
max=a[i][j]; 


cout<<"maxrow"<<i+1<<"="<<max; 
cout<<endl; 
} 
} 
int summat(int a[][c]){ 
int sum=0; 
for(int i=0;i<r;ji++) 
for(int j=0;j<c;j++) 
sum+=a[i][j]; 
return sum; 


void main(){ 
int a[r][c]={1,2,3,4, 
5,6,78, 
9,10,11,12}; 
print(a); 
cout<<endl; 
reverserow(a); 
cout<<endl; 
column(a); 
sumrow(a); 
sumcolumn (a); 
cout<<endl; 
maxcolumn(a); 
cout<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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۾ خالك الاثي 


khaledyassinkh @gmail.com 
maxrow(a); 
cout<<endl; 
cout<<"sum items all 
array="<<summat(a)<<endl; 


/ 
#include<iostream.h> 
#include<iomanip.h> 
void main(){ 
inî [5-20 
int matl][5={1;2;3, 
4,5,6, 
7,8,9}; 
for(int i=0;i<3;i++) 
for( j=0;j<3;jj++) 
1) 20د‎ | )1]222( 
cout<<mat[i][j]<<" "; 


] 

#include<iostream.h> 

char * f1(char *syria,int n,int a[]){ 
cout<<*syria<<endl; 
cout<<syria<<endl; 
cout<<syria[a[n]]<s<endl; 
return syria; 


} 


void main(){ 
char *s="arabic"; 
int a[9]={1,3,4}; 
s=f1(s,4,a); 
cout<<s<<endl; 

1 

#include<iostream.h> 

int max=4; 

int *p=8&max; 

int &f1(int n){ 
max=max+n/2*3+4; 
return max; 

} 

int *f2(int n){ 
*p=*p+n/2+4; 
return زم‎ 

/ 

void main(){ 
f1(max); 
f2(max); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


cout<<max<<endl; 
cout<<*p<<endl; 


المطلوب:كتابة برنامج يعمل على قراءة مصفوفة مربعة يحدد بعدها #include<iostream.h>‏ 
المستخدم ثم يحسب هذا البرنامج: #include<iomanip.h>‏ 
-١‏ مجموع عناصر كل سطر(تابع 01). void read(int *a,int n){‏ 
مجموع عناصر كل عامود(تابع 02). for(int i=0;i<n;i++)‏ 
مجموع كل العناصر(تابع 3م). for(int j=0;j<n;j++){‏ 
اد مجر عتاصر القطر اراسي( ن 4م 
مجموع عناصر القطر الثانوي(تابع 5م). cout<<"["<<i<<"]"<<"["<<j<<"]";‏ 
-٦‏ إجرائيات الطباعة المناسبة. cin>>*(a+n*i+j);}‏ 
ملاحظة: المطلوب تحقيق جميع ما سبق باستخدام المؤشرات } 
حصراً void print(int *a,int n){‏ 
for(int i=0;i<n;i++)‏ 
{ 


for(int j=0;j<n;jj++) 


cout<<*(a+n*i+j)<<setw(4); 
cout<<endl; 
} 
void printarrangement(int suml[],int 
sumc[],int n){ 
for(int i=0;i<n;i++){ 


cout<<"line"<<i+1<<"summery="<<sU 
mI[i]<<endl; 


cout<<"column"<<i+1<<"summery="< 
<sumc[i]<s<endl; 


] 
] 


void p1(int *a,int n,int suml[]){ 
for(int i=0;i<n;ji++) 
{ 
suml[i]=0; 
for(int j=0;j<n;jj++) 
suml[i]+=*(a+n*i+j); 


1 
void p2(int*a,int n,int sumc[]){ 
for(int j=0;j<n;jj++){ 
sumc[j]=0; 
for(int i=0;i<n;ji++) 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي للح‎ 
sumc[j]+=*(a+n*i+j); 
} 
int p3(int suml[],int n ){ 
int sumt=0; 
for(int i=0;i<n;ji++) 
sumt+=suml[i]; 
return sumt; 
} 
int p4(int *a,int n){ 
int sumd=0; 
for(int i=0;i<n;ji++) 
sumd+=*(a+n*i+i); 
return sumd; 
} 
int p5(int *a,int n){ 
int sumd=0; 
for(int i=n;i>0;i--) 
sumd+=*(a+n*(n-i)+(i-1)); 
return sumd; 


} 


void main(){ 
cout<<"enter "<<endl; 
int n; 
cin>>n; 
int *suml=new int[n]; 
int* sumc=new int[n]; 
ME a; 
a=new int *[n]; 
for(int i=0;ji<n;i++) 
a[i]j=new int [n]; 
read(&a[0][0],n); 
p1(&a[0][0],n,suml); 
p2(&a[0][0],n,sumc); 
p3(suml,n); 
print(&a[0][0],n); 
cout<<p3(suml,n)<<endl; 
printarrangement(suml,sumc,n); 
cout<<p4(&a[0][0],n)<<endl; 
cout<<p5(&a[0][0],n)<<endl; 
delete []sumc; 
delete []suml; 
for (i=0;ji<n;ji++) 
delete []a[i]; 
delete []a; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


اكتب برنامج بلغة ++0 يعرف نسق يحوي ١‏ عنصر و المطلوب: 
1 - إجراء لتعبئة عناصر النسق. 
3- إجراء لطباعة عناصر النسق. 


ملااحظة هامة: ما الفرق بين الإجراء sumprev‏ و الإجراء رالاد. 


اكتب إجراء يقوم بحساب وطباعة قواسم عدد ما عدا العدد نفسه عن 
طريق نسق حيث يطلب تخزين هذه القواسم في نسق ثم طباعة 
القواسم على شاشة الحاسب. 

مثال: قواسم العدد 6 هي ,1,2,3 

قواسم العدد 18 هي ,1,2,3,6,9 

قواسم العدد 13 هي 1 

قواسم العدد 100 هي 1,2,4,5,10,20,25,50 


khaledyassinkh @gmail.com 
#include<iostream.h> 
void readmat(int *mat,int n){ 
for(int i=0;i<n;ji++) 
{ 
cout<<"mat["<<i<<"]= "; 
cin>>*(matri); 
} 
} 
void print(int mat[],int n){ 
int i=0; 
for(ji<n;i++) 
cout<<*(mat+i)<<","; 
cout<<endl; 
} 
void sumprev(int mat[],int n){ 
for(int i=1;i<n;ji++) 
mat[i]+=mat[i-1]; 
} 
void sum(int mat[],int temp[],int n){ 
for(int i=0;i<n;ji++) 
temp([i]=mat[i]; 
for(i=1;ji<n;ji++) 
mat[i]+=temp [i-1]; 


void main(){ 
const n=5; 
int mat[n],temp[n]; 
readmat(mat,n); 
print(mat,n); 
sum(mat,temp,n); 
print(mat,n); 
sumprev(temp,n); 
print(temp,n); 

} 

#include<iostream.h> 

void divider(int mat[],int n,int &count){ 

count=0; 

for(int i=1;ji<=n/2;ji++) 

if(n%i==0){ 

mat[count]=i; 

count++; 

} 

} 

void print(int mat[],int n){ 
int i=0; 
for(ji<n;i++) 

cout<<*(mat+i)<<","; 

cout<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 
} 


void main(){ 
const max=200; 
int mat[max];jint زان‎ 
cin>>n; 
divider(mat,n,c); 
print(mat,c); 
1 2 
#include<iostream.h> ثم يختبرها إذا كانت‎ N* ١N اكتب برنامجا يقرأ عناصر مصفوفة مربعة‎ 
#include<math.h> ذات قطر مسيطر أم لا.‎ 
void readmat(int *mat,int n){ ملاحظة : تكون المصفوفة ذات قطر مسيطر إذا كانت القيمة المطلقة لكل‎ 
for (int i=0; i<n;i++) عنصر في القطر الرئيسي أكبر من مجموع القيم المطلقة للعناصر الموجودة‎ 
for (int j=0; j<n;j++){ معه في نفس السطر.‎ 
المصفوفة التالية ذات قطر مسيطر:‎ 
couté<" mall" <<is<" "مي >" "مي"‎ " 
cin>>*(mat+i*n+j); 
} 1 المصفوفة التالية ذات قطر مسيطر‎ 
bool dominant(int *mat,int n){ 
int Sum =0; 
for (int i=0; i < n; i++) { 
for (int j=0; j < n; j++) 
if )i (ز=!‎ 
Sum += abs(*(mat+i*n+j)); 
if (abs(*(mat+i*n+i))<=Sum) 
return false; 
SUM =O; 
/ 
return 1; 
} 
void print(int *mat,int n){ 
for(int i=0;i<n;ji++){ 
for(int j=0;j<n;jj++) 
cout<<*(mat+ti*n+j)<< 
cout<<endl; 


الل 
۴ 


/ 
] 
void main(){ 
const n=3; 
int mat[n][n]; 
readmat(&mat[0][0],n); 
print(&mat[0][0],n); 
if((dominant(&mat[0][0],n))==true) 
cout<<"The Array is 
dominant" <<endl; 
else 
cout <<"The Array is not 
dominant" << endl; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


أكتب برنامج يقرأ نص باللغة الإنكليزية و يحسب طول النص علما أن #include <iostream.h>‏ 
النص ينتهي ب نقطة (.) ثم يحسب عدد كل من الأحرف الصغيرة و ;400 = const int max‏ 
الكبيرة و الأوقام و الرموز الاخرى... void main()‏ 
ملاحظة : سنرمز للحروف الكبيرة ب عع۲ه| 1 
و نرمز للحروف الصغيرة ب !55031 int y, large = 0, small = 0, number =0, other=0;‏ 
و نرمز للأرقام ب مءطمانام char Mat[max];‏ 
و نرمز للرموز الأخرى ب معطغه0 cin >> Mat[0];‏ 
int i=0;‏ 
while ( (Mat[i] != '.'( && (i < max) ) {‏ 
Matli];‏ = لا 
(y <= 90) )‏ هع )65 => if ) (y‏ 
large+t;‏ 
else if ( (y >= 97) && (y <= 122) )‏ 
small++;‏ 
else‏ 
if (y>='0' &&Y<='9'(‏ 
number++;‏ 
else‏ 
other++;‏ 


cin >> Mat[++i]; 

] 

cout >> "large count = " >> large<< endl; 

cout << "small count = " << small << endl; 

cout << "number count = " << number << 

endl; 

cout << "other count = " << other << endl; 

1 

اكتب برنامج بلغة ++ يقرأ سسلسلة من الحروف ثم يقوم بطباعتها بشكل #include<iostream.h>‏ 

معكوس علما أن السلسلة تنتهي بنقطة (.). void main(){‏ 

مثال تم إدخال ."ووه تطبع على الشاشة رهءوام char mat[400];‏ 

تم إدخال .ااج 0036 تطبع على الشاشة 13123000 int i=0;‏ 

cin>>mat[0]; 

while(mat([i]!=".'){ 
cin>>mat[++i]; 

/ 

|0521 

for(int j=i-1;j>=0;j--) 

cout<<mat[j]; 

cout<<endl; 


} 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 
اكتب بلغة ++ تابع 110/001 لحساب القيمة التقريبية لجذر #include<iostream.h>‏ 
تربيعي لعدد حقيقي عندمايصبح القيمة التقريبية للجذر هي 1%. float findroot(float value){‏ 
مثال 4=ھں اھ۷ يرد التابع 1.99939 float testval=1,‏ 
0< #نا|اق/ا يرد التابع 9.96753 fesl,‏ 
5-ueاa/‏ يرد التابع 3.87133 deviation,‏ 
09ع ناج۷ يرد التابع 10.0113 و هكذا دواليك normdev; Û o‏ 


res1=value/testval; 
deviation=res1-testval; 
testval=testval+(deviation/2); 
normdev=(deviation/res1); 
} 
while((normdev>0.01) | |(normdev<- 
0.01((: 
return res1; 
} 
void main(){ 
float n; 
cin>>n; 
cout<<findroot(n)<<endl; 
/ 
int complication(int n){ اھءاامصهء بلغة ++ يقوم بحساب و تدوير عدد‎ ٥۸ اكتب تابع‎ 
if(N%2==0) ۲ إلى عدد من مضاعفات‎ 
return n; اكتب إجرائية "ذم تقوم بطباعة تقريب جميع الأعداد إلى‎ 
else مضاعفات ۲ ضمن المجال المغلق [1..0] (مستفيدا من الطلب‎ 
return n+(2-n%2); الأول)‎ 
} 
void print(int n){ 
for(int i=1;i<=n;ji++) 
cout<<complication (i)<<endl; 


} 
void main(){ 
print(10); 


] 
1 1 1 n 

#include<iostream;h> 21210010101111 1011119 0 
float pow1(float x,int n){ 
float res=1; 5 , 1 

- المطلوب كتابة إجرائية 001/2 لإيجاد × حيث × عدد حقيقي و م عدد for(int i=1;i<=n;ji++)‏ 

صحيح موجب بشكل تكراري. res*=x;‏ 

ملاحظة: (ما الفرق بين التابعين 1 سهم و 2/لاهم) return res;‏ 


صحيح موجب بشكل تكراري. 


} 
void pow2(float x,int n,float &res){ 
res=1; 
MEET 
while(i<=n){ 
res*=x; 
i++; 


4 


۾. خلك الالح اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


1 
} 
void main(){‏ 
IRE;‏ 
float x,res;‏ 
cin>>x>>n;‏ 
cout<<pow1(x,n)<<endl;‏ 
pow2(x,n,res);‏ 
cout<<res<<endl;‏ 
] 
من أنواع الفرز التي مر معنا هو الفرز بالتعويم أو الفقاعات ۲۲٥0ء‏ عاططباط #include<iostream.h>‏ 
و الآن نتطرف إلى نوع آخر من الفرز و هو الفرز بالاختيار ٣0ااءماعء const int n=5;‏ 
+501 و هو عبارة عن فكرة بسيطة و هي البحث عن أصغر عنصر في struct array{‏ 
حال الترتيب التصاعدي ووضعه في بداية المصفوفة و نتابع عملية البحث int a[n];‏ 
في كل مرة عن العنصر الأصغر ثم الأصغر إلى أن نصل ترتيب عناصر } 
المصفوفة . void sortselection(array&a,int size){‏ 
عدد المقارنات في خوارزمية الاختيار هو: for(int i=0;i<n-1;i++){‏ 
int j=i; N*(N-1)/2‏ 
کک for(int k=i+1;jk<n;jk++)‏ 
أي إذا كان عدد عناصر الجدول(النسق)=7 هنا بحاجة إلى عدد من if(a.a[k]<a.a[j])‏ 
المقارنات هو 21 عملية مقارنة. j=k;‏ 
int temp=a.a[i];‏ 
a.a[i]=a.a[j];‏ 
a.a[j]=temp;‏ 
1 
/ 
void print(array a,int n){‏ 
int 1-0:‏ 
while(i<n){‏ 
cout<<a.a[i]<<",";‏ 
i++;‏ 
} 
cout<<endl;‏ 
} 
void main(){‏ 
array a={5,2,3,4,1};‏ 
/*for(int i=0;i<n;ji++)‏ 
a.a[i]=i+1;*/‏ 
print(a,n);‏ 
sortselection(a,n);‏ 
print(a,n);‏ 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


اكتب تابع بلغة ++ح يحول من درجة حرارة على سلم فاهرنهايت إلى القيمة 
المكافئة بالدرجة المئوية 5لأواع© علما أن قانون التحويل هو: 


5 
C= 9 +)-32( 


العودية (التراجعية) ع0ز5الاعع]: 
العودية هي عملية استدعاء التابع لنفسه عدد محلل من المرات 
العودية مكلفة زمنيا و ماديا لجهاز الحاسب حيث تعمل على استهلاك جزء 
كبير من ذاكرة الحاسب الرئيسية حيث كل استدعاء عودي يتعامل من قبل 
الذاكرة بفضاء مستقل عن الاستدعاءات العودية السابقة. ` 
و نحن نعلم أن الحل التكراري يكون حلا أفضل من حيث الوقت و الذاكرة 
و لكننا نلجأ إلى الحل العودي في بعض الأحيان عندما يكون الحل التكراري 
غير واضح و من الناحية النظرية كل خوارزمية تكرارية يقابلها خوارزمية 
عودية و العكس صحيح. 
ملاحظة: يكون الحل العودي مناسبا في الرسم العودي و سنتطرق للرسم 
العودي بالتفصيل الممل؟؟؟؟. 
و المطلوب كتابة تابع بلغة ++ تابع يقوم بحساب العاملي لعدد مدخل 
0!=1 
1!=1 
2!=2*1-2 
5!=5*4*3*2*1-0 
n!=n*(n-1)*(n-2)*‏ 


في المثال العودي يمكن أن نشبه ما يحصل بالذاكرة كالتالي: 


3 output 
First call to م‎ 


countdown 
Num is 2 


Countdown(1); 
second call to 


countdown 
Num is 1 


Countdown(0); 
third call to 
countdown 
Num is 0 


/Ino blastoff! 
/ recursive 


//call 


۾ خالك الائ 


khaledyassinkh @gmail.com 
#include<iostream.h> 
double c(double f){ 
return (5.0/9)*(f-32); 
} 
void main(){ 
double f; 
cin>>f; 
cout<<c(f)<<endl; 


#include<iostream.h> 
int factorial(int x){ 
if(x==0)( 
return (1); 
else 
return (x*factorial(x-1)); 
} 
void main(){ 
int xX; 
cin>>x; 
cout<<x<<"!="<<factorial(x)<<endl; 


#include<iostream.h> 
void countdown (int num){ 
if(num==0) 
cout<< "balstoff"; 
else 
{ 
cout<<num<<"...\n"; 
countdown(num-1); 
ا‎ 
} 
void main(){ 
countdown(2); 
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#include<iostream.h> . المطلوب كتابة تابع عودي "لاء يقوم بجمع عددين صحيحين موجبين‎ 
int sum(int x,int y){ المطلوب كتابع تابع عودي ٤ا" يقوم بضرب عددين صحيحين موجبين.‎ 
if(y==0) 
return X; 
else 
return 1+sum(x,y-1); 
/ 
int mult(unsigned int x,unsigned int y){ 
f(y==0) 
return O; 
else 
return x+mult(x,y-1); 
} 
void main(){ 
int x,y; 
cin>>x>>y; 
cout<<sum(x,y)<<endl; 
cout<<mult(x,y)<<endl; 
] 
#include<iostream.h> اكتب تابع اء عودي لحساب مجموع عناصر نسق صحيح.‎ 
#include<conio.h> 
int sum(int a[],int n){ 


return a[0]; 
return a[n]+sum(a,n-1); 


void main(){ 

#define c5 
int mat[c]={1,20,3,4,5}; 
cout<<sum(mat,c-1); 


1 


- المطلوب كتابة تابع ۷1٠م‏ لإيجاد x‏ حيك بزاعذد كسروى وام عدد #include<iostream.h>‏ 
موحت يشتكل :غود double pow1(double x,int n){‏ 
صحيح موجب بشكل عودي. if(n>0)‏ 


ا 0 0 ١‏ 
- المطلوب كتابة إجرائية ۷2٠٥م‏ عودية لإيجاد × حيث × عدد كسري و return x*pow1(x,n-1);‏ 
م0 عدد صحيح موجب بشكل. else‏ 

ملاحظة: (ما الفرق بين التابعين 1س0م و 2/لاهم) ;1 return‏ 


} 
void pow2(double x,int n,int &res){ 
if(n>0){ 
pow2(x,n-1,res); 
res=res*x; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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} 


void main(){ 
int x,n,res; 
cin>>x>>n; 
cout<<pow1(x,n)<<endl; 
pow2(x,n,res); 
cout<<res<<endl; 


} 


#include<iostream.h> 
int f1(int n){ 
if(n<0) 
return 10; 
else 
return n/2+f1(n-1); 
} 
void main(){ 
int res=f1(f1(5)); 
cout<<res<<endl; 
} 
#include<iostream.h> 
int f1(int n){ 
if(n>0) 
return 0 
else 
return n+f1(n+1); 
int f2(int n){ 
if(n<O)return f1(n); 
else 
return n*f1(-n); 
} 
void main(){ 
int res=f1(4); 
cout<<res<<endl; 
cout<<f1(-3)<<endl; 
cout<<f2(5)<<endl; 
cout<<f2(-4)<<endl; 
cout<<f1(f2(2))<<endl; 
} 
#include<iostream.h> 
int i=0; a. d,e,l,a,h,k, 
void main(){ b. بكارطرةرارع‎ 
char c[10]="khaled."; c. e,e,e,e 
if(cli]!='e') d. e,l,a,h,k, 
{ e. none of the above 
i++; 
main(); علل السبب؟‎ 
cout<<c[i]<<","; 
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1 


1 
#include<iostream.h> اكتب تابع بلغة البرمجة لعج يقوم بإيجاد القاسم المشترك الأعظم لعددين‎ 
int gcd(int x, int y){ صحيحين موجبين بشكل عودي.‎ 
if(x%y==0) لاحظ التابع 01ءع و كيفية كتابة التعليمة فى سطر واحد.‎ 
FêLUrRY; 
else 
return gcd(y,x%y); 
} 
int gcd1(int x,int y){ 
return y==0?x:gcd1(y,Xx%Yy); 
1 
void main(){ 
int X,¥; 
Cin>>x>>y; 
cout<<gCcd(x,y); 
/ 
#include<iostream.h> اكتب بلغة ++ إجرائية عودية ٣زم بطباعة عناصر مصفوفة بشكل‎ 
void swap(int a[],int k){ معكوس.‎ 
int temp=a[k]; الخرج:‎ 
a[k]=a[k+1]; 4,1,2,3,5, 
a[k+1]=temp; 5,4,3,2,1, 
1 
void bubblesort(int *a,int n){ 
for(int i=0;i<n-1;ji++) 
for(int j=0;j<n-1;j++) 
if(a[j]>a[j+1]) 
swap(a,j); 
} 
void print(int a[],int n,int i){ 
if(i<n){ 
print(a,n,i+1); 
cout<<a[i]<<","; 
} 
} 
void main(){ 
#define n 5 
int mat[n]={5,3,2,1,4}; 
print(mat,n,O0); 
cout<<endl; 
bubblesort(mat,n); 
print(mat,n,O); 
cout<<endl; 
] 
#include<iostream.h> 
int sum(int n,int a){ 
if(n>0) 
return sum(n-1,a+n); 
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else 
return a; 
} 
void main(){ 
int x=sum(5,3); 
cout<<x<<endl; 
] 
#include<iostream.h> 
int sum(int x,int y){ 
if(x>0) 
return 1+sum(x-1,y); 
else 
FEetUrN VY; 
} 
void main(){ 
int x=sum(5,3); 
cout<<x<<endl; 
void strange(int n){ 
if(n>O0){ 
strange(n/2); 
cout<<n%2; 
} 
void main(){ 
strange(13); 
} 


. طباعة أجزاء عدد صحيح‎ . 
int strange(int n,int i){ خرج البرنامج هو:‎ 
if(n==0) 
return O; 
else 
return 
(n%10)*pow(2,i)+strange(n/10,i+1); 
] 
void main(){ 
cout<<strange(11111111,0); 


] 
#include<iostream.h> 
int f1(int n,int y){ 
if(n==0| |y==0) 
return n+y; 
else 
return n+y+f1(y-1,n-1); 
} 


void main(){ 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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2,4, 
2, 

2,4,8,16,32, 

جميع ما سبق غير صحيح 


a. 9‏ 
b. 0‏ 
1 .© 
d. 2012‏ 
ملاحظة: عدد مرات تنفيذ الحلقة هو 2010/3670 و في كل مرة يتم 
زيادة العداد بمقدار 3 و منه 670*3-2010 و أول قيمة للعداد هي 1 ومنه 
قيمة العداد بعد الخروج من الحلقة هي 2010+1-2011 


الخرج: 
م 


3 
8 
0 
e 


. 6 


عدد مرات دخول الحلقة هي 5/3=2 ومنه قيمة العداد بعد الخروج من 
الحلقة هي 2*3+2=8 


الخرج: 
a. 1,2,3,4,99,‏ 
,23,4 .م 
Cc. 2,3,4,99,‏ 


۾ خالك الائ 
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int x=f1(4,3); 
cout<<"x="<<x<<endl; 
] 
#include<iostream.h> 
int area(int n){ 
if (A==1) 
return 1; 
else 
return n+n-1+area(n-1); 
} 
void main(){ 
1113 
cout<<area(x)<<endl; 
#include<iostream.h> 
#include<math.h> 
f1(int n){ 
int |; 
for(i=4;ji<=n*n*n;i*=4) 
cout<<sqrt(i)<< 
cout<<endl; 


MM, 
Fp 


} 
void main(){ 
f1(5); 
] 
#include<iostream.h> 
#include<math.h> 
f1(int n){ 
int |, j1; 
for(i=1ji<=n;ji+=3); 
cout<<i<<endl; 
void main(){ 
f1(2010); 
} 


#include<iostream.h> 
#include<math.h> 
f1(int n){ 
int l, j=1; 
for(i=2;ji<=n;ji+=3); 
cout<<i<<endl; 
} 
void main(){ 
1(5); 
] 
#include<iostream.h> 
const int n=5; 
f1(int x){ 
int i=x, a[n]={1,2,3,4,99},*p=(a+2); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك لمم . خلك باي اشح khaledyassinkh @gmail.com‏ 
while(p!=&a[5]) . 2,3,4,‏ 


cout<<*p++<<","; 
0 . 3,4,99, 


] 
void main(){ 

1(5); 
#include<iostream.h> 
#include<math.h> 

inline int f1(int n){ 
return n*(n+1)/2; 
void main(){ 
cout<<f1(100); التابع ۴1 يقوم بحساب:‎ 
} .5-1 مجموع الأعداد من 1 إلى‎ 
.0-2 مجموع الأعداد من 1 إلى‎ 
. مجموع الأعداد من 1 إلى‎ 
.1 مجموع الأعداد من 0-2 إلى‎ . 
.0 مجموع قواسم العدد‎ . 
#include<iostream.h> اكتب تابع عودي يقوم بقسمة عددين صحيحين موجبين و الناتج صحيح‎ 
int mult(int x,int y){ بطريقة الطرح المتكرر.‎ 
if(x==0| | x<y) 
return 0 
else 
return 1+mult(x-y,y); 
/ 
void main(){ 

EE) 

cin>>x>>y; 

cout<<mult(x,y)<<endl; 


} 
اكتب تابع عودي لإيجاد أصغر عنصر في المصفوفة وحيدة الاتجاه. int small(int *a,int size,int value,int index){‏ 
اكتب إجرائية لإيجاد أصغر عنصر في نسق(شعاع) if(size==1)‏ 
return value;‏ 

else 


if((a[index+1]<a[index])) 
value=a[index+1] 
return small(a,size-1,value,index+1); 
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اكتب تابع بلغة ++ع يتحقق من كون عدد مدخل هو عدد أولي أم لا #include<iostream.h>‏ 
ملاحظة: العدد الأولي لا يقبل القسمة إلا على نفسه و الواحد. bool isprime(int x){‏ 
لح IR‏ 
while(x>i){‏ 
if(x%i==0)‏ 
return false;‏ 
else‏ 
if(x%i!=0)‏ 
i++;‏ 
ا 
(دخير) j‏ 
return true;‏ 
/ 
void main(){‏ 
قينا 
cin>>x;‏ 
if (isprime(x))‏ 
cout<<x<<"is prime"<<endl;‏ 
else‏ 
cout<<x<<"is NOt‏ 
prime"<<endl;‏ 


} 
اكتب إجرائية تقوم بطباعة جميع الأعداد الأولية ضمن المجال المغلق #include<iostream.h>‏ 
[×..1] حيث × عدد أكبر من 1 يتم إدخاله من قبل المستخدم. 1( bool isprime(int‏ 

ملاحظة: استفد من التابع م٣1٣‏ مء المكتوب أعلاه. int i=2;‏ 

while(x>i){ 

if(x%i==0) 

return false; 

else 

if(x%i!=0) 
i++; 

if (x==i) 

return true; 

! 
void print(int n){ 

for(int i=2;i<=n;ji++) 

if(isprime(i)) 
cout<<i<<" "; 
cout<<endl; 


void main(){ 
int :ا‎ 
cin>>x; 
print(x); 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


ل لابجنددي. خالك بلسي الاش 
اكتب إجرائية تقوم بطباعة جميع الأعداد الأولية ضمن المجال المغلق 
[×..1] حيث × عدد أكبر من 1 يتم إدخاله من قبل المستخدم. 
ملاحظة: سوف نكتب البرنامج بأسلوب آخر. 
الخرج: 
,2,3,5,7,11 


يعرف العدد الكامل بأنه العدد الذي يساوي مجموع قواسمه ماعدا نفسه 
مثال: العدد 6 هو عدد كامل لأن مجموع قواسمه تساويه: 
1+2+3=6 
-١‏ اكتب إجرائية ٣ع‏ لارا لطباعة قواسم عدد. 
-١‏ اكتب بلغة البرمجة تابع )ممع يتحقق من كون العدد كامل أم لا. 
؟- إجرائية طباعة جميع الأعداد الكاملة الواقعة ضمن المجال المغلق 
[1..9000] مستفيدا من التابع c٥٤)‏ حصرا. 
الخرج: 
6 
,1,2,3 
28 
,1,2,4,7,14 
496 
,1,2,4,8,16,31,62,124,248 
8128 
,1,2,4,8,16,32,64,127,254,508,1016,2032,4064 


۾ خالك اللشييت 
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#include<iostream.h> 
bool prime(int n){ 

bool b=0; 

if(n==2)return 1; 


for(int i=2;i<n;ji=i+1) 
if(n%i==0){ 
b=0; 
break;} 
else 
b=1; 
return b; 
} 
void print(int n){ 
INÊ 22 
while(i<=n){ 
if(prime(i)) 
CcoUut<<İ<< 


MI, 
7 


i++; 


7 


} 


void main(){ 
MEXE 
print(x); 


#include<iostream.h> 
void divider(int n){ 
for(int i=1;ji<=n/2;i++) 
if(n%i==0) 


1 اليج يراوه 
cout<<endl;‏ 


} 


bool check(int n){ 

int sum=0; 

for(int i=1ji<=n/2ji++) 
if(n%i==0) 

sum+=i; 

if(n==sum) 
return true; 
else 
return false; 


void complete(int max){ 


for(int i=1;ji<=max;i++){ 
if(check(i)){ 
cout<<i<<endl; 
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divider(i);‏ 
ا 


] 
] 


void main(){ 
complete(9000); 


} 


نقول عن عددين أنهما صديقان مم,م إذا كان مجموع قواسم العدد ٩‏ هو ۸ #include <iostream.h>‏ 
و مجموع قواسم العدد M‏ هو bool check(int n,int m){ ١.‏ 
و العددان 220و 284 مثال على ذلك. int s1=0,s2=0;‏ 
و المطلوب for(int i=1ji<=n/2ji++)‏ 
-١‏ اكتب بلغة البرمجة تابع )ععع يتحقق من كون العددان صديقان أم if(n%i==0)‏ 
ا s1+=i;‏ 
for(i=1;ji<=m/2;i++)‏ 
؟- اكتب برنامج لإيجاد جميع الأعداد الصديقة ضمن المجال المغلق if (m%i==0)‏ 
[1..4000] مستفيدا من التابع »اعع»احع حصراً. ;أ=+s2‏ 
if(s1==m && s2==n)‏ 
return 1;‏ 


return Oj 
} 
void search(int max){ 

int s1=0,s2=0; 

for(int n=1;jn<=max;jn++) 

for(int i=1;i<=n;ji++) 

if(check(n,i) &&n!=i) 

cout<<n<<" "<<i<<endl; 


} 


void main(){ 
search(4000); 


} 
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اكتب تابع يتم فيه إدخال م عدد صحيح ثم يتم جمع هذه الأعداد المدخلة. #include<iostream.h>‏ 
int addn(int n){‏ 

;1,5=0= ]ذا 

while(i++<=n){ 

REX; 

cout<<"enter the number"<<i-1<< 

cin>>x; 

S+=X; 

} 


return s; 


i i 
1 


} 


void main(){ 
int n; 
cin>>n; 
cout<<addn(n)<<endl; 


#include<iostream.h> 
void print(int n){ 
for(int i=5;i>=1;i--){ 
for(int j=i;jj>=1;j--) 
COU: 
cout<<endl; 
ا‎ 
} 


void main(){ 
print(5); 
} 


#include<iostream.h> 
template <typename t> X=25 
t func(t n){ 2-5 
return n*n; ملاحظة:‎ 
) template<class تكافئ التعليمة‎ template<typename t> التعليمة‎ 
void main(){ t> 
int x; و التعليمة ۴٥ل ع مرا تستخدم لتعريف متحول على أنه نمط من معطيات‎ 
typedef double y; معينة فمثلا © 2۲ط 8/0606 تدل على أن ع هو نمط معطيات من نوع‎ 
X=5; > محرف. أي نستطيع الآن أن نصرح عن متحول على أنه من نمط‎ 
x=func(x); مثال ;× ع أي × متحول من نمط جا‎ 
cout<<"x="<<x<<endl; 
YZ; 
255.5; 
z=func(2); 
cout<<"z="<<2<<endl; 


۾. خلك اللشيدج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك يالميي اشح khaledyassinkh @gmail.com‏ 
ذكرنا في الجزء الأول من الكتاب مايلي: #include<iostream.h>‏ 
strut‏ عبارة عن بنية يمكن أن تحوي أنماط مختلفة من المعطيات (يمكن struct date{‏ 

أن نشبه بالحقيبة التي يمكن تحوي أوراق و أقلام و دفاتر و حقيبة أخرى int day;‏ 

(حقيبة بقلب حقيبة) الخ) . و البرنامج يوضح ذلك. :[30]طغممم char‏ 

int year; الخرج:‎ 
} Welcome ti syria 
struct person{ 

char name[30]; 

date Date; 
J 
struct mountain{ 

char name[30]; 

int height; 

person climber; 
j 
void main(){ 
mountain m={"Everset", 

8848, 

١ 

"Edmund hillary", 

١ 

29 
"may", 
19109 

} 

} 

1 
if(m.climber.Date.year==1919) 
cout<<"welcome to syria"<<endl; 


] 
#include<iostream.h> 
struct mountain{ everset 8848 
char name[30]; 
int height; 
}info={"everset", 8848}; 
void sayAbout(mountain); 
void main(void){ 
mountain k1; 
k1=info; 
sayAbout(k1); 
} 
void sayAbout(mountain m){ 
cout<<m.name<<" 
"<<m.height<<endl; 


] 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 

#include<stdio.h> الخرج:‎ 

#include<string.h> Ali Omar 

ملاحظة: يقوم التابع رمء٣]ء‏ بأخذ و سيطين الوسيط الأول مصفوفة struct tag{‏ 
الحروف و التي تكون ذات طول مناسب لتخزين به قيمة الوسيط الثاني مع char Iname[20] ;/* last name*/‏ 
الحرف الصفري و الثاني يمثل سلسلة من الحروف يتم نسخها إلى الوسيط char fname([20];//first name‏ 
الأول مع الحرف الصفري . float rate;‏ 

و هذا التابع موجود في المكتبة string.h‏ لذلك يجب تضمينها قبل التعامل } 

struct tag my_struct; ف‎ 

int main(void){ 
strcpy(my_struct.lIname,"Omar"); 
strcpy(my_struct.fname,"Ali"); 
printf("%s ",my_struct.fname); 
printf("%s\n",my_struct.lIname); 
return 0 


#include<stdio.h> 

#include<string.h> Ali Omar 

struct tag{ Ali Omar 40 
char Iname[20] ;/* last name*/ 
char fname([20];//first name 
int age; 
float rate; 

1 

struct tag my_struct; 

void show_name(struct tag* p); 

int main(void){ 
struct tag *st_ptr; 
st_ptr=&my_struct; 
strcpy(my_struct.lIname,"Omar"); 
strcpy(my_struct.fname,"Ali"); 
printf("%s ",my_struct.fname); 
printf("%s\n ",my_struct.lIname); 
my_struct.age=40; 
show_name(st_ptr); 


return O; 

} 

void show_name(struct tag *p){ 
printf("%s ",p->fname); 
printf("%s ",p->Iname); 
printf("%d\n",p->age); 


۾. خلك اللشيدج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


36 1238 41 2 
11223346 8 


الخرج: 


الخرج: 
2 123841 36 
8 11223346 
قارن التابع ٠2۲م‏ صهء مع التابع ع2مممهع في البرنامج أعلاه. 
اختر الإجابة الصحيحة: 
الفرق بين الفرز الداخلي و الترتيب(الفرز) الخارجي هو: 
. لايوجد فرق بينهما 
الترتيب الخارجي هو الترتيب الذي يحدث خارج الذاكرة 
الرئيسية 
الترتيب الداخلى هو ما يحدث فى الذاكرة الرئيسية عندما تكون 
حجم البيانات ليست كبيرة بحيث يمكن استيعابها بالذاكرة الرئيسية 
.d‏ (*)ط. وع. 
كل ما سبق خاطئ 


۾ خالك اللشيدت 


khaledyassinkh @gmail.com 
#include<stdio.h> 
int arr[10]={3,6,1,2,3,8,4,1,7,2}; 
void bubble(int *p,int n); 
int compare(int *m,int *n); 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
printf("%d ",a[i]); 
putchar('\n'); 
} 


void main(void){ 
print(arr,10); 
bubble(arr,10); 
print(arr,10); 
} 
void bubble(int *p,int n){ 
in jj 
for(i=n-1ji>=0;i--) 
for(j=1;j<=ijj++) 
if(compare(&p[i-1],&p[j])) 
{ 
t=p[j-1]; 
pli-1]=pli]l; 
pli]=t; 
} 
int compare(int *m,int *n){ 
return (*m>*n); 
#include<stdio.h> 
int arr[10]={3,6,1,2,3,8,4,1,7,2}; 
void bubble(int *p,int n); 
int compare(void *m,void *n); 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
printf("%d ",a[i]); 
putchar('\n'); 
} 


void main(void){ 
print(arr, 10); 
bubble(arr,10); 
print(arr,10); 
} 
void bubble(int *p,int n){ 
كا‎ Lj; 
for(i=n-1ji>=0;i--) 
for(j=1;j<=ijj++) 
if(compare(&p[i-1],&p[i1)) 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


{ 
t=p[j-1]; 
plj-1J=pli]; 
plj]=t; 
} 
} 
int compare(void *m,void *n){ 
IRE MIL AI; 
m1=(int *)m; 
n1=(int *)n; 
return (*m1>*n1); 


#include<iostream.h> 
int main(){ 

|] 337,136 

void *p1=&x,*p2=&y; 
5 ML, M2; 

p1=&y; p2=&x; 
m1=(int *) p1; 
m2=(int *)p2; 
*m1=*m2+3; 
*m2=*m1+5; 
cout<<*m1<<endl; 
cout<<*m2<<endl; 


return O; 
1 
#include<stdio.h> 
void main(void){ array=0012FF78 
&array[0]=0012FF78 
&array=0012FF78 
char a[5]; 
printf(" array=%p\n&array[0]=%p\n 
&array=%p\n",a,&a[0],&a); 
} 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


لك اهمس . خلك بلميي للح 
الخرج: 
OxO0012FF7C‏ 
O0012FF7C‏ 


اكتب برنامج بلغة ++ع تقوم بطباعة الأعداد الصحيحة المحصورة بين × و 
ر أي ضمن المجال المغلق [ر..»] 
مثال: 3=× و 5= أو 5=× و 3= (اجعل محتوى × تحمل الرقم الأصغر 
دوما) يتم طباعة مايلي: 

your number 3 

your number 4 

your number 5 


يو جد فى مشتشفى المواساة عدد من المرضى فى غرفة واحدة و فى هذه 
الغرفة يوجد طبيب واحد فقط و من الصعب على هذا الطبيب مراقبة هؤلاء 
المرضى جميعا في آن واحد. 

أكتب برنامج لتحذير الطبيب بوجود خطر على حياة إحدى المرضى و ذلك 
بسبب ارتفاع درجة حرارته إلى 39 و هذه الدرجة تعتبر خطرة على حياة 
المريض مما يستدعي مساعدة عاجلة من الطبيب لتخفيض درجة حرارة 
المريض 

بحيث يكون هذا التحذير على شكل صوت تنبيه يخرج من جهاز الكمبيوتر. 
مع العلم أنه يتم قياس درجة حرارة المريض بفارق نصف درجة في كل 
مرحلة. 

نحن نعلم أن درجة الإنسان الطبيعية هي ٠۷‏ 

عدل البرنامج بحيث يتم إصدار صوت لمدة خمس دقائق و في حال إدخال 
أي محرف من لوحة المفاتيح من قبل الطبيب يتوقف إصدار الصوت. 


۾ خالك الائ 


khaledyassinkh @gmail.com 


#include<stdio.h> 
#include<iostream.h> 
void main(void){ 


int xX; 

cout<<&x<<endl; 
char a[5]; 
printf("%p \n",&x); 


#include<iostream.h> 
void print(int x,int y){ 
001 
cout<<"your number 
"<<x<<endl; 
XH+; 
} 
while(x<=y); 
} 
void main(){ 
int a,b; 
cin>>a>>b; 
if(a>b){ 


b=a/b; 
a=a/b;} 


print(a,b); 
] 
#include<iostream.h> 
void watch (float t){ 
int x=1; 
while (t<=40){ 
if(tE=39K 
for(;:){ 


cout<<"temperature ="<<t<<endl; 


if(x%15==0){ 
cout<<x<<endl; 
break; } 
cout<<x<<endl; 
++X; 


1 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 
t=t+0.5;‏ 
1 


void main(){ 
watch(36); 
} 


ما هو عمل البرنامج: #include<iostream.h>‏ 
ه. طباعة عناصر ما تحت القطر الرئيسى void main(){‏ 
ط. طباعة عناصر ما فوق القطر الرئيسي int mat[3][3]={1,2,3,4,5,6,7,8,9};‏ 
©. طباعة عناصر ما تحت القطر الثانوي for(int i=0;i<3;i++){‏ 
0. طباعة عناصر ما فوق القطر الثانوي for(int j=0;j<3;j++)‏ 
.Dgy.a .e‏ ا 

cout<s<mat[i][j]<<" "; 


1 


ما هو عمل البرنامج: #include<iostream.h>‏ 
ه. طباعة عناصر ما تحت القطر الرئيسي void main(){‏ 
ط. طباعة عناصر ما فوق القطر الرئيسى int mat[3][3]={1,2,3,4,5,6,7,8,9};‏ 
©. طباعة عناصر ما تحت القطر الثانوي for(int i=0;i<3;i++){‏ 
0. طباعة عناصر ما فوق القطر الثانوي for(int j=0;j<3;j++)‏ 
.Dg.a .e‏ (ز>)؟ا 


cout<<mat[i][j]<<" "; 


۾. خلك لالج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك لابجتددبي. خلك يالميي اشح 
الخرج: 
enter the value x:9‏ 
number is=9‏ 
ملاحظة: تعليمة ۴" هعءء تعليمة لإدخال المعلومات من لوحة المفاتيح 
keyboard‏ 


enter the value x and y:9 10 
9 + 10-9 


ملاحظة: المؤثر >> يسمى بمؤثر الإزاحة اليساري ]11 !5 اما 
و المؤثر << يسمى بمؤثر الإزاحة إلى اليمين” :8118 8104 . 
و التعليمة (×>>ل)=ل تعني إزاحة المتحول ل بمقدار 7 بتات(خانات). 


11 0| 0 0)| 0 0 0 0 
8 حلا بعد الإزاحة إلى اليسار بسبع خانات كالتالي: 


م0 010 0 م 0 10 


و التعليمة (لإ<<»)=×تعني إزاحة المتحول 7=× بمقدار 1 بت إلى 
اليمين: 

01111 0 0 0 0 
تصبح بعد الإزاحة قيمة 3=× كالتالي: 
00000011 


۾ خالك الائ 


khaledyassinkh @gmail.com 


#include<stdio.h> 
void main(){ 


int x;//input 9 
printf("enter the value x:"); 
scanf("%d",&x); 
printf("number is=%d\n",x); 


#include<stdio.h> 
void main(){ 


int x,y; //input x=9 , ¥Ş=10 
printf("enter the value x and y:"); 
scanf("%d%d",&x,&y); 

printf("%d + %d= %d\n",x, رلا‎ x+y); 


} 


#include<iostream.h> 
void main(){ 


int X=7,J=1; 
cout<<(y<<x)<<endl;; 
cout<<(x>>y)<<endl; 
y=(y<<x); 

x=(x>>y); 
cout<<y<<endl; 
cout<<x<<endl; 


#include<iostream.h> 
void main(){ 


int a=5,b=6; 
cout<<(a>b)<<endl; 
cout<<!(a>b)<<endl; 
cout<<(a&8&b==a)<<endl; 
cout<<(a && b)<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي اشح‎ 
cout<<(a&b)<<endl; 
cout<<(a^b)<<endl; 
cout<<(a | |b)<<endl; 
cout<<(a | b)<<endl; 
cout<<(a>>1)<<endl; 
cout<<(a<<2)<<endl; 
cout<<!a<<endl; 
cout<<”a<<endl; 


cout<<”b<<endl; 


#include<iostream.h> الدالة رجام تقوم بالانتظار لوقت محدد بالثواني‎ 
#include<stdio.h> 
#include<time.h> 
void delay(int sec); 
void main(){ 
int wait; 
cout<<"enter wait"; 
cin>>wait; 
delay(wait); 
cout<<"time "<<endl; 
} 
void delay(int sec){ 
int s; 
for(;:){ 
s=clock()/CLOCKS_PER_SEC; 
if(s==sec) 
break; 


} 


اكتب إجراء 501/1 عودي لخوارزمية الفرز بالفقاعات. #include<iostream.h>‏ 
اكتب إجراء 01101 عودي لطباعة عناصر نسق. void sort(int b[],int size){‏ 
اكتب إجراء 2۲2¥ هم لقراءة عناصر نسق بشكل عودي. for(int i=0;i<size-1;i++)‏ 
ملاحظة: يجب على المستخدم للبرنامج تحديد حجم النسق. if(b[il]>b[i+1]){‏ 
int temp=b[i];‏ 
b[i]=b[i+1];‏ 
b[i+1]=temp;‏ 
} 
if(size>1)‏ 
sort(b,size-1);‏ 


} 
void readarray(int b[],int i,int size){ 
if(i<size){ 
cout<<"enter the 
b["<<i<<"]"<<endl; 
cin>>b[i]; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


درجة تعقيد التابع ۴1 هو: 


عمل التابع ۴1 هو: 


.a 


جمع عناصر مصفوفة المربعة. 


ط. جمع عناصر ما تحت القطر الرئيسي فى المصفوفة. 


الجواب الصحيح يختلف عما سبق. 


۾ خلك اللشيدت 


khaledyassinkh @gmail.com 
readarray(b,i+1,size); 
} 
} 
void print(int b[],int i,int size){ 
if(i<size){ 
cout<<b[i]<<","; 
print(b,i+1,size); 
} 
} 
void main(){ 
cout<<"enter number size 
array"<<endl; 
MEG; 
cin>>c; 
#define n c 
int * b=new int[n]; 
readarray(b,0,n); 
cout<<endl; 
print(b,O,n); 
sort(b,n); 
cout<<"\nafter sort"<<endl; 
print(b,O,n); 
delete[]b; 
cout<<endl; 
} 
#include<iostream.h> 
int f1(int **p,int c){ 
int res=O; 
for(int i=0;i<c;i++) 
for(int j=0;j<ijj++) 
res=res+*(*(p+i)+j); 


return res; 
} 
void print(int **p,int n){ 
int i,j; 
for(i=0;i<n;ji++){ 
for( j=0;j<n;j++) 


cout<<*(*(p+i)+j)<<"\t"; 
cout<<endl; 


void main(){ 
Int 623: 
IME ** aj 
a=new int *[c]; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي اشح‎ 
for(int i=0;i<c;i++) 
a[i]j=new int[c]; 
for(i=0;i<c;ji++) 
for(int j=0;j<c;j++) 
*(*(a+i)+j)=i+j; 
print(a,c); 
cout<<"f1="<<f1(a,c)<<endl; 
for(i=0;i<c;ji++) 
delete[]a[i]; 
delete[]a; 


الخرج: #include<iostream.h>‏ 
double p1(double x,unsigned int n){ 36‏ 
التابع 1م يقوم بحساب "× حيث × عدد كسري و ۸ عدد صحيح موجب. double res=1;‏ 
while(n>0){‏ 
if(n%2!=0) res=res*x;‏ 
بر بدي 
n=n/2;‏ 
} 
return res;‏ 
] 
void main(){‏ 
double x=6;‏ 
int n=2;‏ 
cout<<p1(x,n)<<endl;‏ 
1 
اكتب برنامج بلغة ++ للتعامل مع الأعداد العقدية و المطلوب: #include<iostream.h>‏ 
-١‏ إجرائية ل همم لقراءة عدد عقدي. #include<math.h>‏ 
۲- إجرائية(دالة) ٣م‏ لطباعة عدد عقدي. struct num{‏ 
۳- تابع(دالة) اء لحساب مجموع عددين عقديين. float re;‏ 
-٤‏ تابع نو لحساب طرح عددين عقديين. float im;‏ 
5- تابع ام لحساب ضرب عددين عقديين. 1 
1- تابع بزل لحساب قسمة عددين عقديين. void read(num&);‏ 
۷- تابع + لحساب طويلة عدد عقدي. void print(num&);‏ 
num sum(num&,num&);‏ 
num sub(num&,num&);‏ 
num mult(num&,num&);‏ 
num div(num&,num&);‏ 
double t(num);‏ 
void main(){‏ 
num X,¥,Z;‏ 
read(x);‏ 
read(y);‏ 
cout<<"‏ 


print(x); 
cout<<endl; 
print(y); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي للح khaledyassinkh @gmail.com‏ 


cout<<" 


z=sUm(x,y); 
cout<<"sum="; 
print(z); 

cout<<endl; 
2=sub(x,y); 
cout<<"sub=";print(z);jcout<s<endl; 
z=mult(x,y); 
cout<<"mult=";print(z);cout<<endl; 
z=div(x,¥); 
coltsé"diy="; 
print(z);cout<<endl; 
cout<<t(x)<<endl; 
cout<<t(y)<<endl; 


} 


void read(num&x){ 
cin>>x.re; 
cin>>x.im; 


} 
void print(num& x){ 
cout<<x.re<<"+"<<x.im<<"l";} 


num sum(num&x,num&y){ 
num x1; 
x1.re=x.re+y.re; 
x1.im=x.im+y.im; 
return x1; 

} 

num sub(num&x,num&y){ 
num x1; 
x1.re=x.re-y.re; 
x1.im=x.im-y.im; 
return x1; 

} 

num mult(num&x,num & y){ 
num x1; 
x1.re=(x.re*y.re)-(x.im*y.im); 
x1.im=(x.re*y.im)+(y.re*x.im); 
return x1; 

} 

num div(num&x,num&y){ 
num x1,¥1,z; 
float m; 
y1.re=y.re; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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y1.im=-y.im; 
x1=mult(x,y1); 
m=pow(y.re,2)+pow(y.im,2); 
z.re=x1.re/m; 
z.im=x1.im/m; 
return Z; 

} 

double t(num x){ 
return sqrt(pow(x.re,2)+pow(x.im,2)); 


اكتب بلغة ++ع برنامج للتعامل مع التاريخ على اعتبار أن التاريخ يمثل #include<iostream.h>‏ 

بل اليوم و مم الشهر و ل السنة. struct date{‏ 
=١‏ تابع rad‏ لقراءة تاريخ. int d,m,y;‏ 

إجرائية ماةل†” ن٣م‏ لطباعة تاريخ بالشكل إ/رمط/0. 1 

تابع c٠ مa۲٥2d 2t٥‏ يقوم بالمقارنة بين تاريخين و يعيد القيمة date read(date);‏ 

1 في حال كان التاريخ الأول أكبر تماما من التاريخ الثاني و إلا void printdate(date);‏ 

فإنه يعيد القيمة 0. bool compare2date(date,date);‏ 

ملاحظة: int main(){‏ 
الإدخال يتم على الشكل التالي: date x,y;‏ 
إدخال اليوم 0 x=read(x);‏ 
إدخال الشهر y=read(y); ١‏ 
إدخال السنة لا printdate(x);‏ 
printdate(y);‏ 
cout<<"‏ 
cout<<compare2date(x,y)<<endl;‏ 


} 


date read(date x){ 
cin>>x.d; 
cin>>x.m; 
cin>>x.y; 
return xX; 
} 
void printdate(date x){ 
cout<<x.d<<"/"<<x.m<<"/"<<x.y<<end 
و‎ 
} 
bool compare2date(date x,date y){ 
if(x.y>Y¥.¥) 
return true; 
else 
if(x.m>y.m) 
return true; 
else 
if(x.d>y.d) 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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return 1;‏ 

else 

return false; 


اكتب برنامج بلغة ++ يقوم بتخزين بيانات طلاب السنة الأولى في كلية #include<iostream.h>‏ 
الهندسة المعلوماتية بجامعة دمشق حيث يعرف كل طالب من خلال رقم struct student{‏ 
ذاتي معطا موللا يتكرر) و اسم ۳٥‏ هم بالإضافة إلى علامات المواد int number;‏ 
التالية: char name[30];‏ 
الرياضيات جص 081١م int‏ 
البرمجة١‏ 1ع08م 94n tar;‏ 
الإنكليزي مع int en;‏ 
العربي /2 int math;‏ 
و العلامة النهائية من 100 و جميع العلامات صحيحة. float av;‏ 
ملاحظة يجب معالجة حالة تكرار إدخال رقم طالب موجود . } 
والمطلوب: void read(student a[],int n){‏ 
اقترح بنية معطيات مناسبة لتخزين بيانات الطالب. for(int i=O;i<n;ji++){‏ 
-١‏ إجرائية لهه لقراءة البيانات الخاصة بكل طالب. cin>>a[i].number;‏ 
"- إجرائية 505400604 تقوم بترتيب عناصر بيانات الطلاب for(int j=0;j<=i-1;j++){‏ 
تنازليا حسب المعدل. 


if(a[j].number==a[i].number){ إجرائية خم نوزم لطباعة اسم الطالب و رقمه و معدله.‎ -٤ 


cout<<"replay"<<endl; 
cin>>a[i].number; 


while(a[j].number==a[i].number) 


{ 
cout<<"replay"; 


cin>>a[i].number; 


cin>>a[i].name; 
cin>>a[i].math; 
cin>>a[i].prog1; 
cin>>a[i].en; 
cin>>a[i].ar; 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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a[i].av=(a[i].math+a[i].prog1+a[i].en+a 
[i].ar)/4.0; 
} 
} 
void sortstudent(student a[],int n){ 
for(int i=1;i<n;ji++) 
for(int j=0;j<n-1;j++) 
if(a[j].av<a[j+1].av) 
{ 
student 
temp=a|[j]; 
alj]=a[j+1]; 
a[j+1]=temp; 
} 
} 
void printstudent(student *a,int n){ 
for(int i=0;i<n;ji++) 
cout<<af[i].number<<"\t"<<a[i].name< 
<"\t"<<a[i].av<<endl; 


} 


void main(){ 
#define max 3 
student a[max]; 
read(a,max); 
sortstudent(a,max); 
printstudent(a,max); 
] 
#include<iostream.h> لدينا بيانات تتضمن معلومات عن موظفي كلية الهندسة المعلوماتية بجامعة‎ 
struct birthday{ دمشق تتضمن بيانات الموظف المعلومات التالية:‎ 
int d,m,y; رقم ذاتي ,)عنام علما أن رقم الموظف يعطى بشكل تسلسلي حصرا(أي‎ 
2 الموظف الذي يتم إدخال بياناته أولا يأخذ الرقم 1 و الموظف الثاني الرقم‎ 
1 و هكذا....)‎ 
struct employee{ first_name الاسم الآول‎ 
int number; الكنية ©206م_356|‎ 
char first_name([30]; تاريخ الميلاد و يتضمن اليوم 0 و الشهر ص و السنة ر‎ 
char last_name[30]; 521231 الراتب‎ 
birthday birth; : ++ و المطلوب كتابة برنامج بلغة البرمجة‎ 
double salary; اقترح بينة معطيات مناسبة لتخزين بيانات الموظف.‎ -١ 
5 ؟- تابع لقراءة بيانات الموظف.‎ 
employee read(employee e){ إجرائية تقوم بترتيب بيانات الموظفين ترتيبا تنازليا حسب‎ 
static int i=1; الراتب.‎ 
e.number=i++; إجرائية أطباعة اتات الموظفين على اة ا‎ 
cout<<"number=";cout<<e.number<< عل الطلب الكاني يحيك ع الدع إجزائية اي تابخ ا يغيد‎ 


endl; 
cout<<"first_name="; 
cin>>e.first_name; 
cout<<"last_name="; 


void read(employee & e){ 
static int i=1; 
e.number=i++; 
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cin>>e.last_name; cout<<"number=";cout<<e.number<<endl; 
el le E A i hi cout<<"first_name="; cin>>e.first_name; 
<<endl<<"\tday="; cout<<"last_name="; cin>>e.last_name; 
cin>>e.birth.d; cout<<"birthday"<<"*********¥+***''<<endl<<"\tday="; 
cout<<endl<<"\tmonth="; cin>>e.birth.d; 
cin>>e.birth.m; cout<<endl<<"\tmonth="; cin>>e.birth.m; 
cout<<endl<<"\tyear="; cout<<endl<<"\tyear="; cin>>e.birth.y; 
cin>>e.birth.y; cout<<endl<<"salary=";cin>>e.salary; 
cout<<endl<<"salary=";cin>>e.salary; 
return زع‎ 
1 في البرنامج(التابع) الرئيسي نكتب الاستدعاء على الشكل:‎ 
void sortemp(employee e[],int n){ read(e[i]); 
for(int i=0;i<n-1ji++) في قادم‎ C++ ملاحظة:سأشرح بالتفصيل الملفات و كيفية التعامل معها بلغة‎ 
for(int j=0;j<n-1;j++) الصفحات أو (في الجزء الثالث).‎ 


if(e[j].salary<e[j+1].salary){ 
employee 
temp=e[j]; 
eli]=e[j+1]; 
e[j+1]=temp; 
} 
1 
void printemp(employee e[],int n){ 
for(int i=0;i<n;ji++){ 
cout<<"number="; 
cout<<e[i].number<<endl; 
cout<<"firsr_name="; 
cout<<e[i].first_name<<endl; 
cout<<"last_name="; 
cout<<e[i].last_name<<endl; 
cout<<"birthday="; 
cout<<e[i].birth.d<<"- 
"<<e[i].birth.m<<"-"<<e[i].birth.y<<endl; 


cout<<"salary="<<e[i].salary<<endl<<" 
"<<endl; 


} 


void main(){ 
const int max=3; 
employee e[max];; 
for(int i=0;ji<max;i++) 
e[i]=read(e[i]); 
sortemp(e,max); 
printemp(e,max); 


۾. خلك الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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ليكن البرنامج المكتوب على يسارنا بلغة ++ و ليكن ما يلي: #include<iostream.h>‏ 
void main(){‏ 
memory address‏ اسم المتحول int x=5;‏ 
int *p=&x; 5 000127‏ 


cout<<p<<endl; م‎ Ox0012FF78 
cout<<&x<<endl<<&p<<endl; 


و المطلوب خرج البرنامج. p=NULL;‏ 
الخرج هو: cout<<p<<endl;‏ 

cout<<&p<<endl; 5 
//*p=10 error خطأ‎ 5 
OxO0012FF7C 
] Ox0012FF7C 
OxO0012FF78 
))0 
OxO0012FF78 


اختر الإجابة الأكثر دقَة: 
ج. المؤشرات عبارة عن متحولات تحوي قيم في الذاكرة. 


5 


م. (*)المؤشرات عبارة عن متحولات تحوي عناوين في الذاكرة. 
. المؤشرات عبارة عن متحولات تؤشر إلى عناوين بالذاكرة. 
0. المؤشرات عبارة عن متحولات تقوم بعملية تأشير إلى محتوى 
موقع بالذاكرة. 
©. المؤشرات عبارة عن متحولات تحوي مؤشرات في الذاكرة. 
بفرض لدينا : #include<iostream.h>‏ 
Memory address‏ اسم المتحول void main(){‏ 


int *p1=new int, *p2=new int; P1 Ox0012FF7C 
م‎ 
01-57 P2 Ox0012FF78 


p2=p1; 0“ :‏ 
علما أن 1م يؤشر إلى العنوان 0×00421۴۴0 في الذاكرة و المطلوب cout<<p1<<endl;‏ 
خرج البرنامج. 


cout<<p2<<endl; ٠ 
3 الخر ج‎ 

cout<<*p1<<endl; 

cout<<*p2<<endl; 


Ox00421FFO 
Ox00421FFO 
5 

5 
Ox00421FFO 
Ox00421FFO 
99 

99 
0200127 
OxO0012FF78 


delete(p2); 
if(p2!=NULL){ 
cout<<p1<<endl; 
cout<<p2<<endl; 
*p1=99; 
cout<<*p1<<endl; 
cout<<*p2<<endl; 
cout<<&p1<<endl; 


اختر الإجابة الصحيحة: 
ختر الإجاب 2 cout<<&p2<<endl;}‏ 


لنفرض أنه لدينا (104)5 /لاء م-م* غم[ فإنه عند تطبيق التعليمة 
(م)عغهاء0 فهذا يعني: 
المؤشر م أصيح لا يؤشر إلى أي عنوان في الذاكرة. 
المؤشر م أصبح يؤشر إلى العنوان صفر في الذاكرة. 
المؤشر م بقي يؤشر إلى نفس العنوان في الذاكرة. 
يتم حذف محتوى م* من الذاكرة. 


(*)©. و 0. 
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#include<iostream.h> خرج البرنامج هو:‎ 
void main(){ 
int *p1=new int, *p2=new int; . 10 
*p1=5; . 20 
2p: . None of the above 
delete(p2); 


cout<<*p1<<endl; 


#include<iostream.h> 


struct m{ a. 99,55,14 
int y; . 55,4 
1 . 9 
struct k{ . 55,99,14 


int x,y; „. None of the above 
mt; 


J 
k *f(k *r){ 
r->t.y=99; 
r->x=55; 
r->y=(*r).x+(*r).t.y; 
return r; 
} 
void main(){ 
KE 
KX: 
r=&Xx; 
f(8&x); 
cout<<r->t.y<<","; 
cout<<r->x<<","; 
cout<<r->y<<endl; 


۾. خا الج اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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اكتب برنامج بلغة ++ع يقوم بتعريف أنماط المعطيات و التوابع و 
الإجرائيات التي تسمح بقراءة مجموعة من الأسماء مع الأرقام الذاتية 
الخاصة بها و تخزينها في سلسلة ديناميكية المطلوب: 


ب 


إجرائية ٤۲عء"‏ ال هم۲ تقوم ببناء السلسلة مرتبة تصاعديا حسب 
رقم الطالب(علما أن رقم الطالب لا يتكرر و أرقام هي أرقام 
صحيحة موجبة أكبر تماما من الصفر حصرا). 

إجرائية 06١‏ تقوم بحذف العنصر الموافق لرقم ذاتي هو دخل 
الإجرائية مع معالجة محاولة حذف رقم طالب غير موجود. 
إجرائية 30010١‏ تقوم بإضافة عنصر جديد (اسم ورقم 
الظالب)إلى السلسلة مع معالجة عدم إضافة رقم طالب موجود. 
إجرائية اءاا†م ذم تقوم بطباعة عناصر السلسلة على الشكل 
التالي .studentnumber studentnmae‏ 

تابع ءا م† coun‏ يقوم بإعادة عدد عناصر السلسلة. 

إجرائية ©7010/6+01411 تقوم بنقل عناصر السلسلة مرتبة 
تصاعديا حسب الرقم الطالب إلى ملف تسلسلي 5.036 مع 
مراعاة حخذف: العنصر المنقول مباقئرة. 


ملاحظة:التعليمة ۲٥ط‏ ںہ<-م تكافئ التعليمة /عمإابام.(م*) و يجب 
تضمين م* بين قوسين لان النقطة . لها أولوية أعلى من * 


۾ خالك الائ 
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#include<iostream> 
#include<string> 
#include<fstream> 
using namespace std; 
typedef struct student * pstudent; 
struct student{ 
string name; 
int number; 
pstudent next; 
1 
bool search(pstudent p,int k){ 
while(p!=0){ 
if(p->number==k) 
return 1; 
p=p->next; 


return 0 


void readinsert(pstudent& p,student e){ 
if(G==NULL / ==0*/){ 
p=new(student); 
e.next=NULL; 
*p=e;} 
else 
if (p- 
>number>e.number){/*((*p).number>e.numb 
er)*/ 
e.next=p; 
p=new(student); 
*p=e; 


pstudent 
prev,temp=p; 


while ((temp!=0)&8&.(tem p- 
>number<e.number)){ 
prev=temp; 
temp=temp- 
>next; 
1 
e.next=temp; 
prev->next=new 
(student); 
*prev->next=e; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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} 
void del(pstudent&p,student e){ 
if(p!=0) 
if(p->number==e.number){ 
pstudent pr=p; 
p=p->next; 
delete(pr); 


pstudent 
temp=p,prev; 


while ((temp!=0)&8&.(temp- 
>number<e.number)){ 
prev=temp; 
temp=temp- 


} 


prev->next=temp- 


delete(temp); 


void addnew(pstudent &p,student e){ 
if(p->number>e.number){ 
e.next=p; 
p=new student; 
*p=e; 


pstudent temp=p,prev; 
while((temp!=NULL)&&(temp- 
>number<e.number)){ 
prev=temp; 
temp=temp->next; 
} 
e.next=temp; 
prev->next=new(student); 
*prev->next=e; 


void printlist(pstudent p){ 
cout<<"numberstudent"<<"\t"<<"nma 
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estudent"<<endl; 
while(p!=0){ 
cout<<p->number<<"\t"<<p- 
>name<<endl; 
p=p->next; 


} 


int counterlist(pstudent p){ 
if(p==0) 
return 0 
else 
return 1+counterlist(p->next); 


} 


void movetofile(pstudent& p){ 
pstudent temp=p; 
ofstream outfile("f.dat",ios::out); 
while(p!=NULL){ 
temp=p; 
outfile <<p->number<< 


>> -م‎ 
>name<<endl; 
p=p->next; 
delete(temp); 
ا‎ 
/ 
void main(){ 
#define n 3 
pstudent p=0; student زع‎ 
for(int i=1;i<=n;ji++){ 
cin>>e.number; 
while(e.number<=0){ 
cout<<"enter the 
number student>=1"<<endl; 
cin>>e.number; 
} 
cin>>e.name; 
readinsert(p,e); 
} 
printlist(p); 
cout<<"number of student 
is="<<counterlist(p)<<endl; 
cout<<"d"<<endl; 
cin>>e.number; 
if(search(p,e.number)) 
del(p,e); 
else 
cout<<"not found"; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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printlist(p); 
cout<<"add"<<endl; 
cin>>e.number; 
while(search(p,e.number)) 
{ 
cout<<"please enter the 
number"<<endl; 
cin>>e.number; 
} 
while(e.number<=0){ 
cout<<"enter the 
number student>=1"<<endl; 
cin>>e.number; 


} 


cin>>e.name; 


addnew(p,e); 

printlist(p); 

movetofile(p); 
#include<iostream.h> اكتب برنامج بلغة ++ يقوم بالتعامل مع السلاسل (لقوائم) الخطية وحيدة‎ 
#include<conio.h> الاتجاه حيث نفرض انه لدينا البنية التالية:‎ 
struct info{ struct info{ 

int num; int num; 

info * next; info * next; 
}; / 


info * insert(info*,info); و المطلوب:‎ 


-١‏ تابع غ+]ع105 لإضافة أو لحشر عنصر ضمن السلسلة. 
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كل عنصر من السلسلة له الحقول الثالية: 5 
حيث الحقل اعم هو مؤشر إلى العنصر التالي 


تابع 530 للبحث عن عنصر ضمن السلسلة. 
إجرائية print‏ لطباعة عناصر السلسلة. 


num 


في السلسلة أن وجد و في حال أنه لا يؤشر إلى العنصر تالي فإن قيمته 
تساوي |ام أي: 


و يمكننا تخيل شكل السلسلة في الذاكرة كما يلي: 


info* del(info*,info); 
bool search(info*,int); 
void print(info*); 

char choice(); 


void main(){ 
info* head=NULL; 
info زلا‎ 
char c; 
001 
c=(choice()); 
switch (c){ 
case "|: 
case 'i':{ 
cout<<"enter the 
number";cin>>v.num; 


head=insert(head,v);break;} 
case 'D': 
case'd':{cout<<"enter the 
number";jcin>>v.num; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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head=del(head,v); 
break;} 
case 'S': 
case 's':{cout<<"enter the 
number";cin>>v.num; 


cout<<search(head,v.num)<<endl; 
break;} 
case'P': 
case 'p':{cout<<"Diplay the 
linked list"<<endl; 
print(head);break;} 
while(c!='E'&&c!='e'); 


info * insert(info*head,info v){ 
v.next=ÛO; 
info* p=new info(v); 
if(head==0) 
head=p; 
else 


if(v.num<(*head).num){ 
َم‎ 
>next=head; 
head=p; 
} 
else{ 
info 
*p1,*prev; 
p1=head; 


while((p1!=0)&&(p1->num<v.num)) 
{ 


prev=p1; 


p1=p1->next; 
} 
prev->next=p; 
p->next=p1; 
/ 
return head; 


} 


info* del(info*head,info v){ 
info *p,*prev; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com 
if(head->num==v.num){ 
p=head; 
head=head->next; 
delete(p); 
) 
else{ 
p=head; 
while((p!=0)&8&(p- 
>num!=v.num)){ 
prev=p; 
p=p->next; 


} 


if((p!=0)&8&((*p).num==v.num)){ 
prev->next=p- 
2161 
delete(p); 
} 
} 
return head; 
/ 
bool search(info* head,int v){ 
info* p=head; 
while(p!=NULL){ 
if((*p).num==v) 
return true; 
p=p->next; 
return false; 
} 
void print(info *head){ 
info *p=head; 
while(p!=NULL){ 
cout<<p->num<<endl; 
p=p->next; 
} 


char choice(){ 


cout<<"l:inserting to linked 
list"<<endl; 

cout<<"S:searching in linked 
list"<<endl; 

cout<<"p:printing the linked 
list"<<endl; 

cout<<"D:delete from linked 
list"<<endl; 

cout<<"E:exit"<<endl; 

char c; cin>>c; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


return C; 


باستخدام المؤشرات و بنية المكدس اكتب الإجرائيات اللازمة لتحويل عدد #include<iostream.h>‏ 
صحيح موجب أكبر من الصفر إلى ما يكافئه من عشري إلى ثنائي struct list{‏ 
مثال: 8= سے 1000 int n;‏ 
list *next;‏ 
}*ph;‏ 
void push(list*&p,int x){‏ 
if(x!=0){‏ 
if(p==NULL){‏ 
p=new list;‏ 
p->n=x%2;‏ 
p->next=O0;‏ 


list *temp=new list; 
temp->n=x%2; 
temp->next=p; 
p=temp; 
} 
push(p,x/2); 
J 
void pop(list*&p,int &res){ 
if(p!=0){ 
list*e=p; 
p=p->next; 
res=e->n; 
delete(e); 
} 


void main(){ 
ph=0; 
int x,res; cin>>x; push(ph,x); 
while(ph!=0){ 
pop(ph,res); 
cout<<res; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


cout<<endl; 


اكتب برنامج بلغة ++ن يقوم بالتعامل مع السلاسل(القوائم) الخطية ثنائية #include<iostream.h>‏ 
الاتجاه على فرض لدينا حقل واحد للمعطيات وهو الرقم صم #include<conio.h>‏ 
يتضمن البرنامج الإجرائيات التالية: struct info{‏ 
-١‏ إجرائية +/]ع6وم1 لحشر عنصر ضمن السلسلة. int num;‏ 
إجرائية امل لحذف عنصر من السلسلة. info * next,*prev;‏ 
إجرائية print_up‏ لطباعة عناصر المصفوفة تصاعديا ۶ 
إجرائية م/لاه00_غم1/م لطباعة عناصر المصفوفة تنازليا. info *pf=0,*plast=O;‏ 
void insert(info v){‏ 
v.next=0;‏ 
يمكننا تخيل شكل السلسلة ثنائية الاتجاه بالذاكرة كما يلي: hfe:‏ 
كل عنصر من عناصر اللائحة يحوي الحقول التالية: info* temp=new info(v);‏ 
if(pf==0){‏ 
pf=temp;‏ 
حيث الحقل »هم هو مؤشر للعنصر التالي في السلسلة plast=temp;‏ 
و الحقل prev‏ هو مؤشر للعنصر اللاحق(السابق)في السلسلة. 


prev | num | next 


if((*pf).num>v.num){ 
temp->next=pf; 
temp->prev=0; 
pf->prev=temp; 
pf=temp; نهاية السلسلة بداية السلسلة‎ 


info * p1, * p2; 
p1=pf; اختر الإجابة الصحيحة:‎ 

3. في السلسلة الخطية وحيدة الاتجاه لا يوجد مفهوم |أم while(p1!=08&&p1->num<v.num){‏ 

م. في السلسلة الخطية ثنائية الاتجاه لا يوجد مفهوم |أم p2=p1;‏ 

ح. في السلسلة الخطية الدائرية لا يوجد مفهوم |ام p1=p1->next;‏ 

0. كلمة ازم تشير إلى العنوان صفر في الذاكرة } 

if(p1!=0){ .d (*)ء و‎ .e 
temp->next=p1; 
temp->prev=p2; 
p1->prev=temp; 
p2->next=temp; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي للح‎ 
1 
else{ 
temp->prev=p2; 
temp->next=NULL; 
p2->next=temp; 
plast=p2->next; 


} 


} 
void del(info v){ 
info * p1, p2; 
p1=pf; 
p2=p1; 
if(pf!=0){ 
if(p1==pf&8& -1م‎ 
>num==v.num&&p1->next==0) 
{ 
pf=0; 
plast=0; 
delete(p1); 


else 
if(p1==pf&8&p1->num==v.num) 
{ 
pf=pf->next; 
pf->prev=0; 
delete(p1); 


while(p1!=08&&p1->num<v.num) 
{ 


p2=p1; 


p1=p1->next; 
} 


if(p1==plast&&p1->num==v.num) 
{ 


plast=p1->prev; 
plast- 
>next=0; 
delete 
p1; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي للح khaledyassinkh @gmail.com‏ 


if((p1!=0)&&(p1->num==v.num)) 
{ 


p2->next=p1->next; 
p1->next->prev=p2; 
delete(p1); 

else 


cout<<"the element is not 
found"<<endl; 


} 
} 


bool search(int v){ 
info * p=pf; 
while(p!=0){ 
if(p->num==v) 
return true; 
p=p->next; 


} 
return false; 
/ 
void print_up(){ 
info*p=pf; 
while(p!=NULL){ 
cout<<p->num<<endl; 
p=p->next; 
/ 
void print_down(){ 
info* p=plast; 
while(p!=0){ 
cout<<p->num<<endl; 
p=p->prev; 
} 
/ 


char choise(){ 
char; 
cout<<"l:inserting to linked"<<endl; 
cout<<"S:searching in linked"<<endl; 
cout<<"U:printing the linked 
list(UP)"<<endl; 
cout<<"P:printing the linked 
list(Down)"<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 
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cout<<"E:exit"<<endl; 
cout<<"choise="; 

cin>>c; 

return زع‎ 


void main(){ 
info زلا‎ char زع‎ 
001 
c=choise(); 
switch (c){ 
case'i': 
case'l':{ 
cout<<"enter 
the number"<<endl; 
cin>>v.num; 


insert(v);break; 
/ 
case 'd': 
case'D':{cout<<"enter 
the number"<<endl; 
cin>>v.num; 
del(v);break; 
} 
case 's': 
case 'S':{cout<<"enter 
the number"<<endl; 
cin>>v.num; 


if(search(v.num)) 


cout<<"found"<<endl; 
else 


cout<<"not found"<<endl; 
break;} 
case 'u': 
case 
'U':{cout<<"Displaying the linked 
list(UP)"<<endl; 


print_up();break;} 
case 'p': 
case 
'P':{cout<<"displaying the linked 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


اكتب برنامج بلغة ++ يقوم بالتعامل مع السلسلة الدائرية مع تحديد بنية 
معطيات مناسبة علما أن السلسلة لها حقلي معطيات الاسم 03006 و الرقم 
الام . 


كان لدى ملك ظالم طريقة مبتكرة في إعدام معارضيه إذ كان يضعهم على 
محيط دائرة و يبدأ العد بجهة عقارب الساعة ثم يقوم بإعدام الشخص ذو 
العدد م ثم يبدأ العد بعكس عقارب الساعة إلى أن يصل إلى الشخص ذو 
العدد م 

و المطلوب مثل المسألة باستخدام المؤشرات مع اقتراح بنية معطيات 
مناسبة. 

ملاحظة: هذه المسألة باستخدام المؤشرات تحل باستخدام السلسلة 
الدائرية(هنا لا يوجد مفهوم اأہ) 


۾ خالك اللشيدخ 
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list(Down)"<<endl; 
print_down();jbreak;} 


] 
/ 


while(c!='E'&&c!='e'); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


لك للامجددي. خلك بلميي للح 
الخرج: 
welcome to syria‏ 
WELCOME TO SYRIA‏ 
Welcome to syria arabic‏ 
WELCOME TO SYRIA ARABIC‏ 
ملاحظة. يقوم التابع عم ملمغ بأخذ محرف كوسيط ويعيد هذا الحرف 
الكبير الموافق له (حيث يتم تحويل الحروف من 'ه' إلى '2' إلى الحروف 
الكبيرة حسب |85061) و إذا كان الحرف كبير أصلا فإنه يعيده نفسه. 
و التابع +عممبامغ موجود في المكتبة 1.عمراء و لذلك يجب تضمينها 
قبل استخدام التابع. 
رو لدينا التابع ۲س ها الذي يأخذ كوسيط محرف و بتحقق من كونه حرف 
صغير و يرد القيمة 0 في حال كان الحرف غير صغير و هذا التابع 
موجود في المكتبة ط.عملإ6©. 


syria arabic 


طباعة عأطهar‏ aأ٣۷ك.‏ 

طباعة هز٣‏ رك فقط, 

طباعة الحرف ١‏ فقط. 

(*) طباعة الحرف ء بشكل لا نهائي. 
الجواب الصحيح يختلف عما سبق. 


۾ خالك الاي 


khaledyassinkh @gmail.com 
#include<iostream.h> 
#include<ctype.h> 
char * f1(char *p){ 

while(*p!='\0') 

{ 

*p=toupper(*p); 

ptt; 


} 


return زم‎ 
} 
void f1(char p[],int n){ 
int i=0; 
while(i<n){ 
pli]=toupper(p[i]); 
i++} 
] 
void f2(char p[],int n){ 
int i=0; 
while(i<n){ 
if(islower(p([i])) 
p[i]=toupper(p([i]); 
i++} 


} 


void main(){ 
char mat[]="welcome to syria"; 
cout<<mat<<endl; 
f1(mat); 
cout<<mat<<endl; 
char m[]="welcome to syria arabic"; 
cout<<m<<endl; 
f1(m,23); 
cout<<mx<<endl; 
} 
#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 
int i=0; 
while(mat[i]!=0) 
cout<<mat[i++]; 


/ 
#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 


while(*mat!=0) 
cout<<*mat; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


حدلك امم . خلك يې للش 

الخرج: 

„syria arabi ه. طباعة‎ 

ط. طباعة هرك فقط, 

ع. طباعة الحرف وء فقط. 

0. طباعة الحرف و بشكل لا نهائي. 

م. (*)الجواب الصحيح يختلف عما سبق. 
ملاحظة: البرنامج لن ينفذ لأننا نحاول تغيير اسم المصفوفة باستخدام عملية 
حسابية و هذا غير مقبول بلغة ++ع و يمكن الاستعاضة عن ذلك باستخدام 
المؤشرات كالتالي مثلا. 


#include<iostream.h> 
void main(){ 
char mat[13]="syria arabic"; 
char * p=&mat[0];//or char * p=mat; 
while(*p!=0){ 
cout<<*p++; 


الخرج: 
the content in array mat is = welcome to syria arabic‏ 
the content in array 3 is = welcome to syria arabic‏ 
the content in array b is = welcome t‏ 
ملاحظة: 
يقوم التابع /إمع5]8 بأخذ و سيطين الوسيط الأول مصفوفة الحروف و 
التي تكون ذات طول مناسب لتخزين به قيمة الوسيط الثاني مع الحرف 
الصفري و الثاني يمثل سلسلة من الحروف يتم نسخها إلى الوسيط الأول مع 
الحرف الصفري . 
و هذا التابع موجود في المكتبة string.h‏ لذلك يجب تضمينها قبل التعامل 
معه. 
و التابع ومء ١ء‏ بنفس العمل الذي يقوم به التابع ۷مء٣]ء‏ ولكن مع فارق 
بسيط و هو أن التابع رمء٣‏ ٣ء‏ يحدد عدد الحروف الواجب نقلها(نسخها) 
من الوسيط الثاني إلى الوسيط الأول و أيضا يجب إضافة الحرف الصفري 
من قبل المبرمج في حال كان الوسيط الثالث في التابع /إمم/56 أصغر أو 
يساوي طول السلسلة في الوسيط الثاني. 


الخرج: 
syria arabic‏ 
syria‏ 
syria arabicsyria‏ 
syria‏ 
b= syria‏ 
syriasyria arabicsyria‏ 
يقوم التابع جء٣]ء‏ بعملية إضافة للوسيط الناني الذي هو عبارة سلسلة 
حروف إلى الوسيط الأول الدي هو عبارة عن سلسة حروف حيث يحتل 
الحرف الأول من الوسيط الثاني مكان الحرف الصفري '0)' في الوسيط 
الأول و يجب أخذ بعين الاعتبار أن يكون الوسيط الأول الذي هو عبارة 
عن مصفوفة حروف أن يحوي خانات (حجر) كافية ليتم استيعابه مع 


۾ خالك اللشيدخ 
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#include<iostream.h> 
void main(){ 

char mat[13]="syria arabic"; 


while(*mat!=0){ 
cout<<*mat; 
mat++; 


#include<iostream.h> 
#include<string.h> 
void main(void){ 

char mat[]="welcome to syria arabic"; 

char a[30]; 

char b[10]; 

strcpy(a,mat); 

cout<<"the content in array mat is 
='"<<mat<<endl; 

cout<<"the content in array a is 
="<<a<<endl; 

strncpy(b,mat,9); 

b[9]=0;// or b[9]="\0'; 

cout<<"the content in array b is 
="<<b<<endl; 


#include<iostream.h> 
#include<string.h> 
void main(void){ 
char mat[20]="syria arabic"; 
char *a="syria"; 
char b[30]={""};//or char b[10]={'\O'}; 
cout<<mat<<endl<<a<<endl; 
strcat(mat,a); 
cout<<mat<<endl<<a<<endl; 
strncat(b,mat,5); 
cout<<"b="<<b<<endl; 


strcat(b,mat); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


حدالك اهمس . خلك بلميي للح 
الوسيط الثاني كاملا بما فيه الحرف الصفري. 
و يقوم التابع +5602 نفس العمل إلا أنه يحدد عدد الحروف الواجب 
إضافنها(لصقها) من من الوسيط الثاني إلى نهاية الوسيط الأول. 
و يضاف الحرف الصفري إلى السلسلة الناتجة(تلقائيا). 


الخرج: 


يقوم التابع م5660 بمقارنة الوسيط الأول مع الوسيط الثاني حرفا حرفا و 
يعيد القيمة 0 في حال تساوي لس ري ان 
كان الوسيطالسلطلة) الأول اکر من الط الثاني" 

و التابع strn cmp‏ يقوم بنفس العمل إلا أن عملية المقارنة تشمل فقط العدد 
المحدد من الحروف فقط و لا يقوم التابع 5/560 بمقارنة الحروف التي 
تلي الحرف الصفري لإحدى السلسلتين. 


welcome 
tO 
syria 
arabic 
)مخ تتألف‎ ٥۸ مهمة التابع )ها٣ء هي تقسيم سلسلة حروف إلى عدة وحات‎ 
كل وحدة من عدة حروف و يفصل بينها فواصل (قد تكون هذه الفواصل‎ 
فراغات » حروف و علامات ترقيم» حروف...‎ 
يأخذ التابع )ا٣ء وسيطين الوسيط الأول هو السلسلة المراد تقسيمها و‎ 
الوسيط الثاني هو الفاصل بين وحدات السلسلة‎ 
و في البرنامج تشكل الفواصل فراغات.‎ 
و التعليمة‎ 
*p=strtok(mat," "); 
تجعل المتحول م يؤشر إلى وحدة من واحدات السلسلة جم و يدل الوسيط‎ 
الناني أن الفصل بين كل وحة وأخرى هي فراغ.‎ 
حيث يقوم التابع 5/012 بالبحث عن أول وحدة مكونة من حروف يست من‎ 
حروف الفاصل (أي الفراغ) ثم يوجد الحرف الفاصل بعد أول وحدة ويضع‎ 
بدا منها الحرف الصفري '0]'. مما يساعد على تحديد الوحدة التالية التي‎ 
يبحث عنها التابع و يحتفظ التابع 01غ+]غ5 بمؤشر على الحرف التالي للوحدة‎ 
التالية في اة" و يعيد مؤشرا على بداية الوحدة التالية نفسها‎ 
و يساعد الاستدعاء المتتالي للتابع 01+]]وفي تحديد الوحدات التي تتألف‎ 
منها +703 و ذلك باستخدام القيمة اال أو 0 أو '0 بدلا من الوسيط‎ 
الأول‎ 
حيث تفيد القيمة 11ل" أنه يجب على التابع 56/01 متابعة عمله في تحديد‎ 


۾ خالك الائ 
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cout<<b<<endl; 


} 


#include<iostream.h> 

#include<string.h> 

void main(void){ 
char mat[20]="syria arabic"; 
char *a="syria"; 
char b[30]="hello how ara you"; 
cout<<strcmp(mat,a)<<endl; 
cout<<strcmp(a,mat)<<endl; 
cout<<strncmp(mat,a,5)<<endl; 
cout<<strncmp(mat,a,6)<<endl; 
cout<<strncmp(mat,b,3)<<endl; 
cout<<strncmp(b,mat,3)<<endl; 

char *mi= "afd", *mM2=" aê"; 
cout<<strncmp(m1,m2,3)<<endl; 

MILE AGO: 
cout<<strncmp(m1,m2,3)<<endl; 

m1="a"; 

cout<<strncmp(m1,m2,3)<<endl; 


} 


#include<iostream.h> 
#include<string.h> 
void main(){ 
char mat[30]="welcome to syria 
arabic"; 
char *p=strtok(mat," "); 
while(p!=NULL){ 
cout<<p<<endl; 
p=strtok(NULL," "); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


الوحدات اعتبارا من النقطة التي وصل إليها نتيجة الاستدعاء السابق له. 
و في حال عدم تبقي أي وحدة ضمن السلسلة هم" يعيد القيمة 0 أو 
.NULL‏ 


الخرج: في حال الإدخال كان hello to syria‏ 

hello 
لاحظ أن تعليمة ماع تقرأ الحروف المدخلة حتى الوصول إلى فراغ أو‎ 
أو حرف نهاية ملف.‎ '٠0' حرف سطر جديد‎ 
syriasyriasyriahowareyou الخرج: في حال كان الدخل‎ 


syriasyriasyriahowa 
حيث تقوم التعليمة‎ 
cin>>setw(20)>>mat; 
بإخبار المترجم أنه لا يجب أن تزيد عدد حروف المصفوفة عن 6034 عن‎ 
الحد الأقصى للمصفوفة هنا يتم قراءة 19 محرف كحد أعلى و تخزن في‎ 
لتخزين الرقم الصفري.‎ ٠١ و يخصص الحرف رقم‎ 03+ 


hello to syriaJlخدإ الخرج: في حال‎ 
hello to syria 

يسمح التابع ٥1ا‏ مع.” اع بإدخال سطر كامل إلى مصفوفة بما فيها 
الفراغات 
و هذا التابع يأخذ ثلاثة وسطاء بشكل فعلي حيث يكون الوسيط الأول هي 
المصفوفة التي يتم تخزين السطر فيها و طول هذه المصفوفة و الحرف 
الذي يحدد نهاية السطر 'م . 
و ينهي التابع عمله عند قراءة الحرف "8" أو عند الوصول إلى نهاية 
الملف أو عند تجاوز عدد الحروف المدخلة قيمة الوسيط الثاني منقوص 
منها 1 حيث يت تخصيص الحرف الأخير لتخزين الحرف الصفري '0 
و يمكننا كتابة التعليمة 

cin.getline(mat,20,'\n'); 
بالشكل:‎ 


cin.getline(mat,20); 


الخرج: في حال كان الإدخال بياعم khaled‏ 
عم khaled‏ 
عم khaled‏ 


khaledyassinkh @gmail.com 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin>>setw(20)>>mat; 
cout<<mat<<endl; 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat,20,'\n'); 
cout<<mat<<endl; 


#include<iostream.h> 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat, 10); 
cout<<mat<<endl; 
char *p=mat; 
while(*p!=0) 

cout<<*p++; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك يالميي اشح khaledyassinkh @gmail.com‏ 

الخرج: في حال كان الإدخال بياعم #include<iostream.h> khaled‏ 

#include<iomanip.h> 

void main(){ 
char mat[20]; 
cin.getline(mat, 10,'d'); 
cout<<mat<<endl; 
char *p=mat; 
while(*p!=0) 

cout<<*p++; 


] 
#include<iostream.h> sya الخرج: في حال كان الإدخال عماج‎ 
#include<iomanip.h> . syria arabic 
void main(){ . syria 

char mat[20]; . arabic 


cin.getline(mat, 10,'d'); . syria ara 

cout<<mat<<endl; . syria arab 

char *p=mat; . none of the above 

while(*p!=0) 
cout<<*p++; 


] 
#include<iostream.h> الخرج:‎ 
#include<string.h> wel 
void main(){ ome to wor 
char mat[30]="welcome to worcld"; ld 
char *p=strtok(mat,"c"); ملاحظة: الفاصل هنا بين الوحدات هو الحرف ع‎ 
while(p!='\0'){ 
cout<<p<<endl; 
p=strtok(0,"c"); 


#include<iostream.h> 

#include<string.h> 

void main(){ 

ملاحظة: char mat[30]="welcome to syria arabic";‏ 
التابع م516 مهمته حساب طول سلسلة حروف ما حيث يعيد عدد char *m="syria";‏ 
الحروف التي تتكون منها هذه السلسلة من دون حساب الحرف الصفري cout<<strlen(mat)<<endl;‏ 
cout<<strlen(m)<<endl; .\0'‏ 

] 

#include<iostream.h> الخرج:‎ 

#include<stdio.h> the string has 3 space 

ملاحظة: البرنامج يقوم بحساب عدد الفراغات في سلسلة حروف. #include<string.h>‏ 

typedef char * string; 

int countwithspaces(string input); 

void main(void){ 

string mat="welcome to syria arabic"; 

printf("the string has %d 

space\n",countwithspaces(mat)); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


الخرج: 
the string has 3 space‏ 
ملاحظة: لاحظ مهمة التابع عع23م155 


- اكتب تابع اعا بلغة ++ يقوم بإعادة عدد خانات عدد صحيح لا يساوي 
الضور حصراء 

- اكتب تابع ي عا عودي يقوم بنفس مهمة التابع غ0181. 

مثال 123 يرد التابع 3 

0 يرد العدد 5 

1 يرد التابع العدد 6 

4- يرد اتابع 4 و هكذا دواليك 2 
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} 
int countwithspaces(string input){ 
int i,count=O0O; 
for(i=0;i<strlen(input);ji++) 
if(input[i]==' ' ) 
count++; 
return count; 
] 
#include<iostream.h> 
#include<stdio.h> 
#include<string.h> 
typedef char * string; 
static int isspace(char c); 
int countwithspaces(string input); 
void main(void){ 
string mat="welcome to syria arabic"; 
printf("the string has %d 
space\n",countwithspaces(mat)); 
} 
int countwithspaces(string input){ 
int i,count=O; 
for(i=0;i<strlen(input);ji++) 
if(isspace(input[i]) ) 
count++; 
return count; 
static int isspace(char c){ 
"ع‎ 
return 1; 
return O; 
j 
#include<iostream.h> 
int digit(long n){ 
int i=0; 
while(n!=0) 
{ 
i++; 
n=n/10; 
1 
return i; 
} 
int dig(long n){ 
if(n==0) 
return O; 
else 
return 1+dig(n/10); 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


void main(){ 
long n; 
cinšš>A} 
while(n==0){ 
cout<<"please enter 0<كم‎ "; 
درا‎ 
/ 
cout<<digit(n)<<endl; 
cout<<dig(n)<<endl; 
/ 
#include<iostream.h> اكتب تابع "اء عودي مهمته إعادة مجموع الأعداد الصحيحة الموجبة‎ - 
int sum(long n){ ]1..۸[ حصرا ضمن المجال المغلق‎ 
if(n==0) اكتب تابع ل۵٥ اء عودي مهمته جمع الأعداد الصحيحة الفردية‎ - 
return O; ]1..5[ الموجبة حصرا ضمن المجال المغلق‎ 
else 120 مثال 05-15 يرد التابع مء القيمة‎ 
return n+sum(n-1); 64 ويرد التابع لله مء القيمة‎ 
} 
int sumodd(long n){ 
15221 
return 1; 
else 
if(n %2==1( 
return n+sumodd(n-1); 
else 
return sumodd(n-1); 
1 
void main(){ 
long n; 
cin>>n; 
while(n<=0){ 
cout<<"please enter the n>O "; 
cin>>n; 


} 


cout<<sum(n)<<endl; 
cout<<sumodd(n)<<endl; 


1 


اكتب تابع 50000010 عودي يقوم بجمع عناصر نسق ذات الدليل الفردي حصرا #include<iostream.h>‏ 
اكتب تابع "اء عودي مهته إعادة مجموع عناصر نسق. int sum(int *a,int n){‏ 
و يطلب كتابة إجراء جص لهم لقراءة عناصر النسق و إجراء اام if(n==0)‏ 
لطباعة عناصر النسق. return O;‏ 
مثال لدينا النسق التالي: else‏ 

return a[n-1]+sum(a,n-1); 0 1 2 3 4 5 6‏ 
2] 1315161110 
التابع 0061 مناه يعيد القيمة 9 ] 
التابع ناء يعيد القيمة 18 int sumodd(int *a,int n){‏ 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


اكتب إجراء ×2" عودي لإيجاد القيمة العظمى من بين عناصر نسق. 
اكتب إجراء ام لإيحاد أصغر عنصر في نسق. 


۾. خا اللشيدت 
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return 0 
else 
if((n-1)%2==1) 
return a[n- 
1]+sumodd(a,n-1); 
else 
return sumodd(a,n-1); 
} 
void readmat(int *a,int n){ 
for(int i=0;i<n;ji++){ 
cout<<"mat["<<i<<"] "; 
cin>>a[i]; 
} 
} 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
cout<<a[i]<<","; 
cout<<endl; 
void main(){ 
int n; 
cin>>n; 
int * mat=new int [n]; 
readmat(mat,n); 
print(mat,n); 


cout<<"sum="<<sum(mat,n)<<endl; 

if(n!=1) 
cout<<"sumodd="<<sumodd(mat,n)<<endl; 

else 
cهںuا>يدرف زالمع>>"لا يوجد دليل‎ 

delete[]mat; 
] 
#include<iostream.h> 
void max(int a[],int n,int &res){ 

if(n>0){ 

max(a,n-1,res); 
if(a[n]>res) 
res=a[n]; 

} 
void min(int a[],int n,int &res){ 

if(n>O0){ 

min(a,n-1,res); 
if(a[n]<res) 
res=a[n]; 

} 


void readmat(int *a,int n){ 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,ك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 

for(int i=0;i<n;ji++){ 
cout<<"mat["<<i<<"] "; 
cin>>a[i]; 


} 
void print(int a[],int n){ 
for(int i=0;i<n;ji++) 
cout<<a[i]<<", 
cout<<endl; 


} 

void main(){ 
int n; 
cin>>n; 
int * mat=new int [n]; 
readmat(mat,n); 
print(mat,n); 


int res=mat[0]; 
coüt<é"max=":; 
max(mat,n-1,res); 
cout<<res<<endl; 
res=mat[0]; 
min(mat,n-1,res); 
cout<<"min="<<res<<endl; 
delete[]mat; 
] 
#include<iostream.h> لدينا الطريقة التالية في التحقق من كون عدد أولي أم لا و هي كالتالي:‎ 
#include<math.h> نحن نعلم أن أي عدد زوجي عدا 2 هو عدد غير أولي و ان أي عدد يقبل‎ 
bool prime(int n){ القسمة على 2 هو غير أولي.‎ 
if(n<=1) حيث كما نعلم أن العدد الأولي لا يقبل القسمة إلا على نفسه و على الواحد‎ 
return O: مثلا تم إدخال عدد لمعرفة أن كان هذا العد أولي أم لا نبدأ بتجريب قسمة‎ 
int j=(int)sqrt(n); العدد على الاعداد من 2 إلى جذر العدد(دون الجزء العشري) المطلوب‎ 
for(int i=2;i<=jji++) معرفته إن كان اولي أم لا. فقد أثبت علماء الرياضيات أنه للتحقق‎ 
if(n%i==0) من كون العدد اولي يكفي أن نقسم العدد على الأعداد المحصورة بين 2 و‎ 
return false; جذر العدد(دون الجزء العشري)‎ 
return true; فإذا قبل القسمة على إحدى هذه الأعداد بلا باقي فإن هذا العدد غير أولي‎ 
} وإلا فهو أولي. و المطلوب كتابة تابع ٠م بلغة ++ع يقوم بالتحقق من‎ 
void main(){ كون العدد أولي أم لا وفق هذه الطريقة.‎ 
int n; 0-30 الخرج: في حال‎ 
ا‎ P0, 2,3,5,7,11,13,17,19,23,29, 
for(int i=1;ji<=nji++) 
if(prime(i)) 
coutssisé", 


} 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


ااك الابجتددي. خالك يلي لاشم 
اكتب تابع 5||5 يأخذ كوسيط قيمة المبيعات المحققة من قبل موظف 
المبيعات و يعيد التابع مبلغ العمولة و ليس الراتب المستحقة له علما 
أن نسبة العمولة على الشكل التالي: 

4% من قيمة المبيعات المحققة إذا كانت القيمة أقل أو يساوي من ٠٠٠١‏ 
ليرة سورية 

6% من قيمة المبيعات المحققة فيما عدا ذلك. 


اكتب تابع ٤أعال‏ "اء عودي بلغة ++ يأخذ كوسيط عدد صحيح و يرد 
مجموع خانات هذا العدد 

مثال: 0-123 يرد التابع 6. 

۸-4 يرد التابع 10-. 

3م67 يرد التابع 10. و هكذا دواليك n‏ 


اكتب تابع عودي ۷٥١‏ اعا عودي بلغة ++ يقوم بجمع خانات العدد 
التي تقبل القسمة على 2 حصرا. 

مثال: 6-123 يرد التابع 2. 

6-1 يرد التابع 8. 

۸1 يرد التابع 6.وهكذا دواليك 5300 
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#include<iostream.h> 
double sells(int n){ 
(0مدعم)ةا‎ 
return O; 
if(n<=2000) 
return n*0.04; 
else 
return n*0.06; 
} 
void main(){ 
int n; 
cin>>n; 
cout<<sells(n)<<" sp"<<endl; 
#include<iostream.h> 
int sumdigit(int n){ 
if(n==0) 
return O; 
else 
return 
n%10+sumdigit(n/10); 
/ 
void main(){ 
int n; 
cin>>n; 
cout<<sumdigit(n)<<endl; 


#include<iostream.h> 
int digiteven(int n){ 


return 0 


if((N%10)(%2==0) 
return 
n%10+digiteven(n/10); 
else 
return 
digiteven(n/10); 
} 
void main(){ 
inî nj 
cin>>n; 
cout<<digiteven(n)<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح 
البرمجة غرضية التوجه :object oriented program ming(0OP)‏ 
تهدف البرمجة غرضية التوجه إلى تضمين المعطيات (الصفات 
وع]لاطا36) و التوابع و الإجرائيات (الأفعال 2101015 »)أو عمليات 
0م ضمن مكونات تسمى الصفوف 35565ا©. 
يطلق على المعطيات الخاصة بصف بالمعطيات الأعضاء ومرعط اعم 
8 و على التوابع الخاصة بهذا الصف بالتوابع الأعضاء 
member functions‏ 
أو الطرائق 6+80005/ و لاستخدام هذا الصف نشتق منه أغراض ءاءعزطه. 
إذاً يمكننا الآن أن نقول أن الصفوف تساعد على نمذجة الأغراض التي لها عدة 
صفات و التي يتم تمثيلها على شكل معطيات أعضاء members data‏ 
كما يمكنها أن تقوم بتنفيذ عدة أفعال (065311015) أو عمليات 
operations‏ 
و التي يتم تمثيلها على شكل توابع أعضاء member function‏ 
و يتم عريف الصفوف بلغة ++ن بالكلمة المحجوزة 01355 و نستخدم اسم 
الصف لتعريف الأغراض التي تنتمي إليه أما الطرائق 760005 فيتم 
التعامل معها من خلال عملية الاستدعاء من قبل الغرض المشتق منه. 
أفضل مثال نبدأ به هو صف للتعامل مع التاريخ ع023. 
الخرج: 
1-1-1 
3-5-3 
3 
3-1-1 
الشرح: 
يبدأ تعريف الصف مهل بالكلمة المحجوزة 355اع و يتم تحديد جسم 
الصف بالقوسين :(4 حيث ينتهي تعريف الصف بالفاصلة المنقوطة : 
يتضمن الصف المعطيات الأعضاء التالية year ,monthe,day‏ 
و التوابع الأعضاء التالية: 6غ+021 
„setday,setmonthe,setyear,getday,getmonthe,getyear‏ 
„print‏ 
تدعى الأسماء عذاطنام و private‏ و rotectedم‏ بمحددات الوصول 
إلى المعطيات والتوابع الأعضاء المتعلقة بالصف و تنتهي أسماء المحددات 
دائما بنقطتين : مثال (:ع1ادام) و ينتهي مفعول محدد ما بورود اسم محدد 
اخر. 
و جميع المعطيات و التوابع الأعضاء الوارة بعد المحدد عجرأ م لا يمكن 
الوصول إليها إلا من خلال التوابع الأعضاء أو التوابع الأصدقاء 
و لاحظ استخدام العملية الثنائية لتحديد مجال الرؤية :: و ذلك للتوابع 
الأعضاء في الصف مهل و الواردة بعد تعريف الصف حيث يسبق اسم 
التابع ذكر اسم الصف متبوعا بالعملية الثنائية لتحديد مجال الرؤية و على 
اعتبار أنه يمكن أن يكون لعدة توابع أعضاء من صفوف مختلفة الاسم و 
الترويسة نفسها لذلك تقوم العملية الثنائية لتحديد مجال لرؤية بالربط ما بين 
اسم التابع العضو و الصف بحيث يحصل على تحديد وحيد للتوابع الأعضاء 
المرتبطة بسف محدد. و إذا كان التابع © مامأ فليس هناك ضرورة لكتابة 
جسم التابع خارج بنية الصف و أنما يتم ذكرها داخله و كمثال التابع 
.getday‏ 
إعطاء قيم ابتدائية لأغراض صف من خلال البوانڪى :constructors‏ 
عند إنشاء غرض من صف يمكن لمعطياته أن تأخذ قيم ابتدائية بواسطة 
تابع يدعى بالباني مرتبط بهذا الصف و يحمل باني الصف نفس اسم الصف 
و لا يُحدد نمط القيمة المعادة منه و يتم استدعاؤه أتوماتيكيا عند انشاء أي 
غرض من الصف. 
و يوجد ثلاثة أنواع من البواني : 
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#include "iostream.h" 
class date{ 
private:int day,monthe,year; 
public: 
date(int=1,int=1,int=2011); 
date(date&); 
void setday(int); 
void setmonthe (int); 
void setyear(int); 
int getday()const{return day;} 
int getmonthe()const{return monthe;} 
int getyear()const{return year;} 
void print()const; 
~date(){} 
j 
date::date(int d,int m,int y){ 
setday(d); setmonthe(m);setyear(y); 
date::date(date& da){ 
setday(da.day+2); 
setmonthe(da.monthe); 
setyear(da.year); 
} 
void date::setday(int d){day=d;} 
void date::setmonthe(int m){monthe=m;} 
void date::setyear(int y){year=y;} 
void date::print()const{ 
cout<<day<<"-"<<monthe<< 
1! 
void main(){ 
int d,m,y; 
date d1,d2(1,1,2012),d3(d1);; 
// cin>>d>>m>>y; 
02-3 
MES: 
¥=2013; 
d2.setday(d); 
d2.setmonthe(m); 
d2.setyear(y); 
d1.print(); 
d2.print(); 
cout<<d2.getday()<<endl; 
d3.print(); 


<<year<<endl; 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح 
-١‏ الباني الافتراضي 
؟- الباني ذات الوسطاء 
۳- الباني الناسخ 
و يتضمن مثال صف التاريخ على البواني التالية: 
ت باني ذو وسطاء(وسطاء ذات قيم افتراضية) 
date(int=1,int=1,int=2011);‏ 


-١‏ باني ناسخ 


date(date&); 
كيفية الوصول إلى أعضاء الصف:‎ 
تشابه العمليات المستخدمة للوصول إلى اعضاء صف تلك العمليات‎ 
المستخدمة للوصول إلى حقول السجلات و بالتالي للوصول إلى اعضاء‎ 
)- الصف باستخدام العملية (.) مصحوبة باسم الغرض أو باستخدام العملية‎ 
مع اسم الغرض المؤشر.‎ <( 
و يجب ضبط عملية الوصول إلى المعطيات و خاصة المعطيات الخاصة‎ 
بشكل جيد من خلال توابع ٤٥ع و توابع غ56 فعلى سبيل المثال للسماح‎ 
بقراءة قيمة من المعطيات الخاصة نقوم بكتابة التابع العضو من نوع هع‎ 
المناسب للقيام بذلك و للسماح بتعديل قيمة من المعطيات الخاصة نقوم‎ 
بكتابة التابع العضو من النوع 8ه المناسب للقيام بهذه المهمة.‎ 
و يتضمن مثال صف التاريخ مهل توابع الوصول التالية:‎ 
توابع ال غأعع:‎ -۳ 
int getday()const{return day;} 
int getmonthe()const{return monthe;} 
int getyear()const{return year;} 
توابع ال إع5:‎ -٤ 
void date::setday(int d){day=d;} 
void date::setmonthe(int m){monthe=m;} 
void date::setyear(int y){year=y;} 


و يمكننا استدعاء الطرائق 0640005 من خلال مجموعة من الأغراض 


ملاحظة هامة:إذا لم يذكر اسم محدد الصفوف قبل ذكر الأعضاء فهذه 
الأعضاء هي عجرم ضمنا. 
الخرج: 
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#include<iostream.h> 
class ]ا‎ 


void print(){ 
cout<<y<<endl;} 
int زلا‎ 


x(){ y=99;} 
void f(x t){ 
t.print(); 
} 
1 
void main(){ 
XEL 
1171: 
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سبحانك ربنا لا علم لنا إلا ما علمتنا 


,لك امم . خلك جاسي اشح khaledyassinkh @gmail.com‏ 


#include<iostream.h> 

class work{ 

public: 
int :ا‎ 
void print(){ 

cout<<x<<endl;} 

اعد كتابة الصف )۲٥س‏ بحيث يتم تعريف العضو × على أنه عضو خاص } 

و استخدم الباني لأعطاء قيم ابتدائية له من خلال الباني و من خلال تابع void main(void){‏ 
عضو في الصف )٣مس‏ . work Ww;‏ 
work *wp=&w;‏ 
work &wref=w;‏ 
w.x=99;‏ 
w.print();‏ 
wref.x=wref.x-9;‏ 
w.print();‏ 
wref.print();‏ 
Wp->x=5;‏ 
w.print();‏ 
wp->print();‏ 

] 

ملاحظة هامة:إذا لم يذكر اسم محدد الصفوف قبل ذكر الأعضاء فهذه #include<iostream.h>‏ 

الأعضاء هي 1036م ضمناً. class work{‏ 

int x; الخرج:‎ 

public: 

work(int y){x=y;} 


void print(){ 
cout<<x<<endl;} 
void modifity(int y){ 
x=y;} 
j 
void main(void){ 
int y=99; 
work w(y); 
work *wp=&w; 
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work &wref=w; 
y=y-9; 
w.print(); 


w.print(); 
wref.print(); 
wp->mo difity(y); 


w.print(); 
wref.modifity(5); 
w.print(); 


#include<iostream.h> 
class A{ public:A(){cout<<"A ";} 
PAcoUtSE" A": 
class B:public A{ 
public:B(){cout<<"B ";} 
^B(){cout<<""B";} 
1 
class C:public B{ 
public:C(){cout<<"C ";} 
PE oot CB: 
void main(){ 
66 
cout<<endl;} 


#include<iostream.h> 
class A{ public:A(){cout<<"A ";} 
ماوعا مانيو ]زمه‎ AB 0 ”08- 
class B:public A{ 
public:B(){cout<<"B ";} 
^“B(){cout<<""B";} 
j 
class C:public B{ 
public:C({cout<<"C ";} 
ل ع ين‎ 
void main(){ 
166) 
cout<<endl;} 


#include <iostream.h> 
class array 100,300, 
{ 1,2,3,4,5, 
private: 
IA a: 
int dim,i; 
public: 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 


سبحانك ربنا لا علم لنا إلا ما علمتنا 


khaledyassinkh @gmail.com ,لك امم . خلك جاسي للح‎ 
array() 
1 
a=new int[2]; 
dim=2; 
=0; 
} 
array(int |) 
1 
a=new int[l]; 
dim=l; 
i=0; 
} 
void add(int d) 
{ 
if (i>=dim) 
{ 
cout<<"array boud exceed"; 
i=0; 
1 
a[i]=d; 


void print() 

{ 

for (int j=0;j<dim;j++) 
cout<<a[j]<<","; 
cout<<endl; 

} 

1 

void main() 

{ 

array a1,a2(5); 
a1.add(100); 
a1.add(300); 
a1.print(); 
a2.add(1); 
a2.add(2); 
a2.add(3); 
a2.add(4); 
a2.add(5); 
a2.print(); 

] 


اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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#include "iostream" الخرج:‎ 
using namespace std; 
class index 
{ 
private: 
int count; 
public: 
index() 
{ 
count=O0; 
} 
void operator++() 
1 


++COUNt; 


} 


void showdata() 


cout<<count<<endl; 


void main() 
{ 
index c; 
êoOUt<<"1 C=": 
c.showdata(); 
++C; 
oUt >" احج‎ 
c.showdata(); 
++C;; 
coUt<<"3 =: 
c.showdata(); 
ل‎ 
#include<iostream.h> 
class test{ 
public:test(int=0); 
void print()const; 

private: 

IMEX; 
1 
test::test(int value):x(value){} 
void test::print()const{ 


"الي هيه جنانروع 
cout<<this->x<<",";‏ 
cout<<(*this).x<<endl;‏ 


} 


void main(){ 


test t(5); 
t.print(); 
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#include<iostream.h> 
class test{ 
public: 
test(){x=y=5;} 
int X,¥; 


void print()const; 


1 
class op:public test{ 


void test::print()const{ 
cout<<x<<" "<<y<<endl; 
} 
void main(){ 
op t; 
t.X=t.y+T.X; 
t.y=t.X+T.Y; 
t.print(); 
/ 
#include<iostream.h> 
class k{ 
public: 
int X,¥; 
void f(int n,int m){ 
XE 
y=m; 


1 
print(){cout<<X; 
cout<<","<<y<<endl;} 


0 


void main(){ 
k* p1=new kK; 
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k* p2=new k; 
p2=p1; 
p1->f(5,10); 
p2->print(); 


#include<iostream.h> 
class k{ 
int x,y; 
public: 
void f(int n,int m){ 
Xf; 
y=m; 


} 
print(){cout<<X; 
cout<<","<<y<<endl;} 


} 


void main(){ 
k* p1=new k; 
k* p2=new k; 
1م-2م‎ 
p1->f(5,10); 
p2->print(); 


/ 
#include<iostream.h> 
#include<conio.h> 
class t{ 
public: 
| لإ‎ 
void f(int yy){ 
بلالا داكن‎ 
} 
print(); 


! 
t::print(){ 
cout<<x<<","<<y<<endl; 


} 


void main(){ 
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tf;‏ 

t*e; 
e=&r; 
r.f(9); 
e->f(55); 
e->x=99; 
(e XS77; 
r.print(); 
getch(); 


#include<iostream.h> 
class aa{ 
private: 

int a,b; 
public: 


void f(int x,int y) {a=x; b=y;} 
int f1()const {return a*b;} 


void main(){ 
aa p1; 
p1.f(10,250); 
cout<<p1.f1()<<endl; 
] 
#include<iostream.h> 
class A{ A default constructor 
public: B default constructor 
A(){cout<<"A default constructor \n";} 
A(A&){cout<<"A copy constructor A default constructor 
كوا‎ 8 default constructor 
~A(){cout<<"A destructor \n";}}; C default constructor 
class B:public A{ B destructor 
public: A destructor 
B(){cout<<"B default 
constructor \n";} 
B(B&){cout<<"B copy 
constructor \n";} 
^~B(){cout<<"B destructor \n";}}; 


class C{ 
public: 
C(){cout<<"C default 
constructor \n";} 


C(C&){cout<<"C copy 
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constructor \n";} 
~C(){cout<<"C 
destructor \n";} 
private: 
B x2; 
1 
void main(){ 
B b; cout<<endl; 
C* cp=new C;} 


#include<iostream.h> 
class A{ للصفوف سيكون بالجزء الثالث.‎ 
public: 
A(){cout<<"A default constructor \n";} 
A(A8.){cout<<"A copy constructor 
\n";} 
~A(){cout<<"A destructor \n";}}; 
class B:public A{ 
public: 
B(){cout<<"B default 
constructor \n";} 
B(B&){cout<<"B copy 
constructor \n";} 
~B(){cout<<"B destructor \n";}}; 


class C{ 
public: 
C(){cout<<"C default 
constructor \n";} 
C(C&){cout<<"C لاممء‎ 
constructor \n";} 
~C(){cout<<"C 
destructor \n";} 
private: A x1; 
B X2; 
1 
8 fun(C *p,B b); 


void main(){ 
B b; cout<<endl; 
C* cp=new C; 
cout<<"\n before 
call\n"<<endl; 
b=fun(cp,b); 
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8 fun(C *p,B b){ 
cout<<"\nin fun 


A a; cout<<endl; 8 


cout<<endl; 
delete(p); 
cout<<endl; 
return bb; 


"الخسارة الكبرى هى ما يموت فينا و نحن أحياء" 


ناديت باسمك يا إلهي ضارعا إن لم تجبني فمن يجيب بكائي 
أنت الكريم فلا تدعني تائها فلقد عييت من البعد النائي 


مالي سوى أعتاب جودك موئلا فلئن رددت فمن سواك رجائي 


| تجو اأكقخقصة 
کک حح وات لقص 
اع يهم همح حت 
أت قوت 1 ا 


دع الایام تفل ما تشَاء وَطِب تفساآ إا حَكم القضاءً 
ولا تَجْرّع إحادئة الليالي قما لحوادث الدْنيَا بقَاء 


(من شعر الإمام الشافعي رحمه الله) 


(كل ابن أنثى و إن طالت سلامتة يوماً على آلة حدباء محمول) 


(إن أكبر معركة يخوضها الإنسان هي المعركة التي يغير فيها بعض عاداته و سلوكياته) 


۾. خلك اشح اللهم صلي و سلم على سيدنا محمد و على آله وصحبه أجمعين 
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\n"<<endl; 


bb(b); 


